## P1021 QorlQ Integrated Processor Reference Manual

Supports: P1021 and P1012

Document Number: P1021RM

Rev. 6, 01/2013



## **Contents**

**Section number** Title Page Chapter 1 Overview 1.1 1.1.1 1.1.2 1.1.3 Chip-level features 60 1.2 1.2.1 Integrated services router 62 1.2.2 1.3 1.3.1 1.3.2 1.3.3 Integrated security engine (SEC 3.3.2).....65 1.3.4 1.3.5 1.3.6 1.3.7 1.3.8 DDR SDRAM controller 69 1.3.9 High-speed I/O interfaces 69 PCI Express interfaces......70 1.3.9.1 1.3.9.2 1.3.9.3 1.3.10 1.3.11 1.3.12 1.3.13 Device boot locations. 73 1.3.14

| Sec | tion nu  | mber Title                                                            | Page |
|-----|----------|-----------------------------------------------------------------------|------|
|     | 1.3.15   | System performance monitor                                            | 73   |
|     |          | Chapter 2<br>Memory Map                                               |      |
| 2.1 | Overvie  | w                                                                     | 75   |
| 2.2 | Configu  | 76                                                                    |      |
|     | 2.2.1    | Accessing CCSR memory from the local processor                        | 77   |
|     | 2.2.2    | Accessing CCSR memory from external masters                           | 77   |
|     | 2.2.3    | Organization of CCSR space                                            | 78   |
|     |          | 2.2.3.1 General utilities registers                                   | 78   |
|     |          | 2.2.3.1.1 General utilities register organization                     | 79   |
|     |          | 2.2.3.2 Programmable interrupt controller registers                   | 80   |
|     | 2.2.4    | QUICC engine block and CCSR                                           | 81   |
|     | 2.2.5    | Device-specific utilities registers                                   | 82   |
|     | 2.2.6    | CCSR address map                                                      | 83   |
| 2.3 | Local ac | 85                                                                    |      |
|     | 2.3.1    | Precedence of local access windows                                    | 86   |
|     | 2.3.2    | Configuring local access windows                                      | 86   |
|     | 2.3.3    | Distinguishing local access windows from other mapping functions      | 87   |
|     | 2.3.4    | Illegal interaction between local access windows and DDR chip selects | 87   |
|     | 2.3.5    | Local address map example                                             | 87   |
| 2.4 | Local A  | 89                                                                    |      |
|     | 2.4.1    | Local access window n base address register (LAW_LAWBARn)             | 90   |
|     | 2.4.2    | Local access window n attribute register (LAW_LAWARn)                 | 90   |
| 2.5 | Address  | s translation and mapping units                                       | 92   |
|     | 2.5.1    | Address translation                                                   | 92   |
|     | 2.5.2    | Outbound ATMUs                                                        | 93   |
|     | 2.5.3    | Inbound ATMUs                                                         | 93   |
|     |          | 2.5.3.1 Illegal interaction between inbound ATMUs and LAWs            | 94   |

## Chapter 3 Signal Descriptions

| 3.1 | General overview |               |                                                          |     |  |  |
|-----|------------------|---------------|----------------------------------------------------------|-----|--|--|
| 3.2 | Signals overview |               |                                                          |     |  |  |
| 3.3 | Configu          | 106           |                                                          |     |  |  |
| 3.4 | Output           | Signal States | s During Reset                                           | 108 |  |  |
| 3.5 | Parallel         | I/O ports     |                                                          | 110 |  |  |
|     | 3.5.1            | QUICC e       | engine block port block diagram                          | 111 |  |  |
|     | 3.5.2            | Port pins     | functions                                                | 112 |  |  |
|     |                  | 3.5.2.1       | General purpose I/O pins                                 | 113 |  |  |
|     |                  | 3.5.2.2       | Dedicated pins                                           | 113 |  |  |
|     | 3.5.3            | QUICC e       | engine port interrupts                                   | 113 |  |  |
|     | 3.5.4            | QE Memo       | ory Map/Register Definition                              | 114 |  |  |
|     |                  | 3.54.1        | QUICC Engine Port Interrupt Event Register (QE_CEPIER)   | 114 |  |  |
|     |                  | 3.54.2        | QUICC Engine Port Interrupt Mask Register (QE_CEPIMR)    | 116 |  |  |
|     |                  | 3.54.3        | QUICC Engine Port Interrupt Control Register (QE_CEPICR) | 117 |  |  |
|     | 3.5.5            | Ports Tab     | oles                                                     | 118 |  |  |
|     |                  |               | Chapter 4                                                |     |  |  |
|     |                  |               | Reset, Clocking, and Initialization                      |     |  |  |
| 4.1 |                  |               |                                                          |     |  |  |
| 4.2 |                  |               | al descriptions                                          |     |  |  |
|     | 4.2.1            | •             | ontrol signals                                           |     |  |  |
|     | 4.2.2            | _             | nals                                                     |     |  |  |
| 4.3 |                  |               | ation, control, and status registers                     |     |  |  |
|     | 4.3.1            |               | CCSRBAR                                                  |     |  |  |
|     | 4.3.2            | Accessing     | g alternate configuration space                          | 137 |  |  |
|     | 4.3.3            | Boot page     | e translation                                            | 138 |  |  |
|     | 4.3.4            | Boot sequ     | uencer                                                   | 138 |  |  |

| Sec | tion nu | ımber           | Title                                                                      | Page |
|-----|---------|-----------------|----------------------------------------------------------------------------|------|
| 4.4 | Reset M | Memory Map/     | /Register Definition                                                       | 138  |
|     | 4.4.1   | Configura       | ation, control, and status registers base address register (reset_CCSRBAR) | 139  |
|     | 4.4.2   | Alternate       | configuration base address register (reset_ALTCBAR)                        | 140  |
|     | 4.4.3   | Alternate       | configuration attribute register (reset_ALTCAR)                            | 140  |
|     | 4.4.4   | Boot page       | e translation register (reset_BPTR)                                        | 141  |
| 4.5 | Functio | nal description | on                                                                         | 141  |
|     | 4.5.1   | Reset ope       | rations                                                                    | 141  |
|     |         | 4.5.1.1         | Soft reset                                                                 | 142  |
|     |         | 4.5.1.2         | Hard reset                                                                 | 142  |
|     | 4.5.2   | Power-on        | reset sequence                                                             | 142  |
|     | 4.5.3   | Power-on        | reset configuration                                                        | 144  |
|     |         | 4.5.3.1         | System PLL ratio                                                           | 145  |
|     |         | 4.5.3.2         | DDR PLL ratio                                                              | 146  |
|     |         | 4.5.3.3         | e500 core PLL ratios.                                                      | 146  |
|     |         | 4.5.3.4         | Boot ROM location                                                          | 147  |
|     |         | 4.5.3.5         | Host/agent configuration.                                                  | 148  |
|     |         | 4.5.3.6         | I/O port selection.                                                        | 149  |
|     |         | 4.5.3.7         | CPU boot configuration.                                                    | 150  |
|     |         | 4.5.3.8         | Boot sequencer configuration                                               | 151  |
|     |         | 4.5.3.9         | DDR SDRAM type                                                             | 152  |
|     |         | 4.5.3.10        | SerDes reference clock configuration                                       | 152  |
|     |         | 4.5.3.11        | eTSECn configuration.                                                      | 153  |
|     |         |                 | 4.5.3.11.1 eTSEC3 SGMII mode                                               | 153  |
|     |         |                 | 4.5.3.11.2 eTSEC1 width                                                    | 154  |
|     |         |                 | 4.5.3.11.3 eTSEC1 protocol                                                 | 154  |
|     |         |                 | 4.5.3.11.4 eTSEC3 protocol                                                 | 155  |
|     |         | 4.5.3.12        | Memory debug configuration.                                                | 156  |
|     |         | 4.5.3.13        | DDR debug configuration.                                                   | 156  |
|     |         | 4.5.3.14        | General-purpose POR configuration.                                         | 157  |
|     |         |                 |                                                                            |      |

| Sec | tion nu   | ımber         | Title                                                               | Page |
|-----|-----------|---------------|---------------------------------------------------------------------|------|
|     |           | 4.5.3.15      | Engineering use POR configuration.                                  | 157  |
|     |           | 4.5.3.16      | eLBC ECC enable configuration                                       | 157  |
|     |           | 4.5.3.17      | System speed                                                        | 158  |
|     |           | 4.5.3.18      | Platform speed                                                      | 158  |
|     |           | 4.5.3.19      | Core 0 speed                                                        | 159  |
|     |           | 4.5.3.20      | Core 1 speed.                                                       | 159  |
|     |           | 4.5.3.21      | DDR speed                                                           | 160  |
|     |           | 4.5.3.22      | eSDHC card-detect polarity select                                   | 160  |
|     | 4.5.4     | Voltage se    | election configuration                                              | 161  |
|     | 4.5.5     | Clocking.     |                                                                     | 162  |
|     |           | 4.5.5.1       | System clock and DDR controller complex clock                       | 162  |
|     |           | 4.5.5.2       | PCI Express clock                                                   | 164  |
|     |           |               | 4.5.5.2.1 Minimum frequency requirements                            | 165  |
|     |           | 4.5.5.3       | SGMII clocks                                                        | 165  |
|     |           | 4.5.5.4       | Ethernet clocks                                                     | 165  |
|     |           | 4.5.5.5       | Real time clock                                                     | 166  |
| 4.6 | Initializ | ation/applica | ations information                                                  | 167  |
|     | 4.6.1     | eSDHC b       | oot                                                                 | 167  |
|     |           | 4.6.1.1       | eSDHC boot overview                                                 | 168  |
|     |           | 4.6.1.2       | eSDHC boot features                                                 | 169  |
|     |           | 4.6.1.3       | SD/MMC card data structure                                          | 169  |
|     |           |               | 4.6.1.3.1 SD/MMC configuration words section                        | 171  |
|     |           |               | 4.6.1.3.2 Notes on compatibility with FAT12/FAT16/FAT32 filesystems | 173  |
|     |           | 4.6.1.4       | eSDHC controller initial configuration.                             | 174  |
|     |           | 4.6.1.5       | eSDHC controller boot sequence                                      | 175  |
|     |           | 4.6.1.6       | eSDHC boot error handling                                           | 175  |
|     | 4.6.2     | eSPI boot     | ROM                                                                 | 177  |
|     |           | 4.6.2.1       | eSPI boot overview                                                  | 177  |
|     |           | 4.6.2.2       | Features.                                                           | 178  |
|     |           |               |                                                                     |      |

| Sec | Section number |               |                  | Title                                                     |     |
|-----|----------------|---------------|------------------|-----------------------------------------------------------|-----|
|     |                | 4.6.2.3       | EEPROM (         | data structure                                            | 179 |
|     |                |               | 4.6.2.3.1        | EEPROM configuration words section                        | 180 |
|     |                | 4.6.2.4       | eSPI contro      | oller configuration                                       | 182 |
|     | 4.6.3          | Default e     | 500 addressing   | g during system boot                                      | 184 |
|     |                |               |                  | Chapter 5 e500 Core Integration Details                   |     |
| 5.1 | Overvie        | ew            |                  |                                                           | 187 |
| 5.2 | e500 co        | re block dia  | gram             |                                                           | 188 |
| 5.3 | e500 co        | re integratio | on and the core  | complex bus (CCB)                                         | 190 |
| 5.4 | Summa          | ry of core in | tegration detai  | ils                                                       | 192 |
|     | 5.4.1          | Processor     | r version regist | ter (PVR) and system version register (SVR)               | 194 |
|     |                |               |                  | Chapter 6<br>L2 Look-Aside Cache/SRAM                     |     |
| 6.1 | Introduc       | ction         |                  |                                                           | 195 |
| 6.2 | L2 cach        | ne overview.  |                  |                                                           | 195 |
|     | 6.2.1          | L2 cache      | and SRAM fe      | atures                                                    | 196 |
| 6.3 | L2 cach        | e and SRAN    | M organization   |                                                           | 198 |
|     | 6.3.1          | Accessing     | g the on-chip a  | nrray as an L2 cache                                      | 199 |
|     | 6.3.2          | Accessing     | g the on-chip a  | nrray as an SRAM                                          | 200 |
|     | 6.3.3          | Connection    | on of the on-ch  | nip memory to the system                                  | 202 |
| 6.4 | L2 cach        | ne external w | rite registers   |                                                           | 203 |
| 6.5 | L2 men         | nory-mapped   | d SRAM regist    | ters                                                      | 204 |
| 6.6 | L2 error       | r registers   |                  |                                                           | 204 |
| 6.7 | L2_Cac         | the memory    | map/register d   | efinition                                                 | 205 |
|     | 6.7.1          | L2 contro     | ol register (L2_ | _Cache_L2CTL)                                             | 206 |
|     | 6.7.2          | L2 cache      | way allocation   | n for processors (L2_Cache_L2CWAP)                        | 211 |
|     | 6.7.3          | L2 cache      | external write   | address register n (L2_Cache_L2CEWARn)                    | 213 |
|     | 6.7.4          | L2 cache      | external write   | address register extended address n (L2_Cache_L2CEWAREAn) | 213 |
|     | 6.7.5          | L2 cache      | external write   | control register n (L2_Cache_L2CEWCRn)                    | 214 |

| Sec  | tion nu                     | mber Title                                                                           | Page |  |
|------|-----------------------------|--------------------------------------------------------------------------------------|------|--|
|      | 6.7.6                       | L2 memory-mapped SRAM base address register n (L2_Cache_L2SRBARn)                    | 215  |  |
|      | 6.7.7                       | L2 memory-mapped SRAM base address register extended address n (L2_Cache_L2SRBAREAn) | 216  |  |
|      | 6.7.8                       | L2 error injection mask high register (L2_Cache_L2ERRINJHI)                          | 217  |  |
|      | 6.7.9                       | L2 error injection mask low register (L2_Cache_L2ERRINJLO)                           | 218  |  |
|      | 6.7.10                      | L2 error injection tag/ECC control register (L2_Cache_L2ERRINJCTL)                   | 218  |  |
|      | 6.7.11                      | L2 error data high capture register (L2_Cache_L2CAPTDATAHI)                          | 219  |  |
|      | 6.7.12                      | L2 error data low capture register (L2_Cache_L2CAPTDATALO)                           | 220  |  |
|      | 6.7.13                      | L2 error syndrome register (L2_Cache_L2CAPTECC)                                      | 220  |  |
|      | 6.7.14                      | L2 error detect register (L2_Cache_L2ERRDET)                                         | 222  |  |
|      | 6.7.15                      | L2 error disable register (L2_Cache_L2ERRDIS)                                        | 224  |  |
|      | 6.7.16                      | L2 error interrupt enable register (L2_Cache_L2ERRINTEN)                             | 226  |  |
|      | 6.7.17                      | L2 error attributes capture register (L2_Cache_L2ERRATTR)                            | 228  |  |
|      | 6.7.18                      | L2 error address capture register low (L2_Cache_L2ERRADDRL)                          | 230  |  |
|      | 6.7.19                      | L2 error address capture register high (L2_Cache_L2ERRADDRH)                         | 230  |  |
|      | 6.7.20                      | L2 error control register (L2_Cache_L2ERRCTL)                                        | 231  |  |
| 6.8  | External                    | writes to the L2 cache (cache stashing)                                              | 231  |  |
|      | 6.8.1                       | Stash-only cache regions                                                             | 232  |  |
| 6.9  | L2 cache                    | e timing                                                                             | 232  |  |
| 6.10 | L2 cache and SRAM coherency |                                                                                      |      |  |
|      | 6.10.1                      | L2 cache coherency rules                                                             | 234  |  |
|      | 6.10.2                      | Memory-mapped SRAM coherency rules                                                   | 236  |  |
| 6.11 | L2 cache                    | e locking                                                                            | 236  |  |
|      | 6.11.1                      | Locking the entire L2 cache                                                          | 236  |  |
|      | 6.11.2                      | Locking programmed memory ranges.                                                    | 237  |  |
|      | 6.11.3                      | Locking selected lines                                                               | 237  |  |
|      | 6.11.4                      | Clearing locks on selected lines                                                     | 238  |  |
|      | 6.11.5                      | Flash clearing of instruction and data locks                                         | 238  |  |
|      | 6.11.6                      | Locks with stale data                                                                | 238  |  |

| Sec  | tion nu  | mber Title                                                | Page |  |
|------|----------|-----------------------------------------------------------|------|--|
| 6.12 | PLRU L   | .2 replacement policy                                     | 239  |  |
|      | 6.12.1   | PLRU bit update considerations                            | 239  |  |
|      | 6.12.2   | Allocation of lines                                       | 240  |  |
| 6.13 | L2 cache | 241                                                       |      |  |
|      | 6.13.1   | Initialization                                            | 241  |  |
|      |          | 6.13.1.1 L2 cache initialization                          | 241  |  |
|      |          | 6.13.1.2 Memory-mapped SRAM initialization                | 242  |  |
|      | 6.13.2   | Flash invalidation of the L2 cache.                       | 242  |  |
|      | 6.13.3   | Managing errors                                           | 243  |  |
|      |          | 6.13.3.1 ECC errors                                       | 243  |  |
|      |          | 6.13.3.2 Tag parity errors                                | 243  |  |
|      | 6.13.4   | L2 cache states                                           | 243  |  |
|      | 6.13.5   | L2 state transitions.                                     | 244  |  |
| 6.14 | Error ch | ecking and correcting (ECC)                               | 249  |  |
|      |          | Chapter 7 e500 Coherency Module                           |      |  |
| 7.1  | Introduc | tion                                                      | 251  |  |
|      | 7.1.1    | Overview                                                  | 252  |  |
|      | 7.1.2    | Features                                                  | 252  |  |
| 7.2  | ECM me   | emory map/register definition                             | 253  |  |
|      | 7.2.1    | 7.2.1 ECM CCB address configuration register (ECM_EEBACR) |      |  |
|      | 7.2.2    | ECM CCB port configuration register (ECM_EEBPCR)          | 255  |  |
|      | 7.2.3    | ECM IP Block Revision Register 1 (ECM_EIPBRR1)            | 257  |  |
|      | 7.2.4    | ECM IP Block Revision Register 2 (ECM_EIPBRR2)            | 257  |  |
|      | 7.2.5    | ECM error detect register (ECM_EEDR)                      | 258  |  |
|      | 7.2.6    | ECM error enable register (ECM_EEER)                      | 259  |  |
|      | 7.2.7    | ECM error attributes capture register (ECM_EEATR)         | 260  |  |
|      | 7.2.8    | ECM error low address capture register (ECM_EELADR)       | 262  |  |
|      | 7.2.9    | ECM error high address capture register (ECM_EEHADR)      | 262  |  |
|      |          |                                                           |      |  |

| Sec | tion nu   | ımber Title                                             | Page |
|-----|-----------|---------------------------------------------------------|------|
| 7.3 | Functio   | nal description                                         | 263  |
|     | 7.3.1     | I/O arbiter                                             | 263  |
|     | 7.3.2     | CCB arbiter                                             | 263  |
|     | 7.3.3     | Transaction queue                                       | 264  |
|     | 7.3.4     | Global data multiplexor                                 | 264  |
|     | 7.3.5     | CCB interface.                                          | 264  |
| 7.4 | Initializ | cation/application information                          | 265  |
|     |           | Chapter 8 DDR Memory Controllers                        |      |
| 8.1 | Introdu   | ction                                                   | 267  |
| 8.2 | Feature   | S                                                       | 268  |
|     | 8.2.1     | Modes of operation                                      | 269  |
| 8.3 | Externa   | ıl signal descriptions                                  |      |
|     | 8.3.1     | Signals overview                                        | 269  |
|     | 8.3.2     | Detailed signal descriptions.                           | 271  |
|     |           | 8.3.2.1 Memory interface signals                        | 271  |
|     |           | 8.3.2.2 Clock interface signals                         |      |
| 8.4 |           | nemory map/register definition                          |      |
|     | 8.4.1     | Chip select n memory bounds (DDR_CSn_BNDS)              |      |
|     | 8.4.2     |                                                         |      |
|     | 8.4.3     | Chip select n configuration 2 (DDR_CSn_CONFIG_2)        |      |
|     | 8.4.4     | DDR SDRAM timing configuration 3 (DDR_TIMING_CFG_3)     |      |
|     | 8.4.5     | DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)     |      |
|     | 8.4.6     | DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)     |      |
|     | 8.4.7     | DDR SDRAM timing configuration 2 (DDR_TIMING_CFG_2)     |      |
|     | 8.4.8     | DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG)     |      |
|     | 8.4.9     | DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2) |      |
|     | 8.4.10    | DDR SDRAM mode configuration (DDR_DDR_SDRAM_MODE)       |      |
|     | 8.4.11    | DDR SDRAM mode configuration 2 (DDR_DDR_SDRAM_MODE_2)   | 302  |

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

| Section num | ber Title                                                            | Page |  |
|-------------|----------------------------------------------------------------------|------|--|
| 8.4.12      | DDR SDRAM mode control (DDR_DDR_SDRAM_MD_CNTL)                       | 302  |  |
| 8.4.13      | DDR SDRAM interval configuration (DDR_DDR_SDRAM_INTERVAL)            | 306  |  |
| 8.4.14      | DDR SDRAM data initialization (DDR_DDR_DATA_INIT)                    | 306  |  |
| 8.4.15      | DDR SDRAM clock control (DDR_DDR_SDRAM_CLK_CNTL)                     | 307  |  |
| 8.4.16      | DDR training initialization address (DDR_DDR_INIT_ADDR)              | 308  |  |
| 8.4.17      | DDR training initialization extended address (DDR_DDR_INIT_EXT_ADDR) | 309  |  |
| 8.4.18      | DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                  | 310  |  |
| 8.4.19      | DDR SDRAM timing configuration 5 (DDR_TIMING_CFG_5)                  | 313  |  |
| 8.4.20      | DDR ZQ calibration control (DDR_DDR_ZQ_CNTL)                         | 315  |  |
| 8.4.21      | DDR write leveling control (DDR_DDR_WRLVL_CNTL)                      | 317  |  |
| 8.4.22      | DDR Self Refresh Counter (DDR_DDR_SR_CNTR)                           | 320  |  |
| 8.4.23      | DDR Register Control Words 1 (DDR_DDR_SDRAM_RCW_1)                   | 321  |  |
| 8.4.24      | DDR Register Control Words 2 (DDR_DDR_SDRAM_RCW_2)                   | 322  |  |
| 8.4.25      | DDR write leveling control 2 (DDR_DDR_WRLVL_CNTL_2)                  | 323  |  |
| 8.4.26      | DDR write leveling control 3 (DDR_DDR_WRLVL_CNTL_3)                  | 325  |  |
| 8.4.27      | DDR Debug Status Register 1 (DDR_DDRDSR_1)                           | 328  |  |
| 8.4.28      | DDR Debug Status Register 2 (DDR_DDRDSR_2)                           | 329  |  |
| 8.4.29      | DDR Control Driver Register 1 (DDR_DDRCDR_1)                         | 329  |  |
| 8.4.30      | DDR Control Driver Register 2 (DDR_DDRCDR_2)                         | 333  |  |
| 8.4.31      | DDR IP block revision 1 (DDR_DDR_IP_REV1)                            | 334  |  |
| 8.4.32      | DDR IP block revision 2 (DDR_DDR_IP_REV2)                            | 334  |  |
| 8.4.33      | Memory data path error injection mask high (DDR_DATA_ERR_INJECT_HI)  | 335  |  |
| 8.4.34      | Memory data path error injection mask low (DDR_DATA_ERR_INJECT_LO)   | 335  |  |
| 8.4.35      | Memory data path error injection mask ECC (DDR_ERR_INJECT)           | 336  |  |
| 8.4.36      | Memory data path read capture high (DDR_CAPTURE_DATA_HI)             | 337  |  |
| 8.4.37      | Memory data path read capture low (DDR_CAPTURE_DATA_LO)              | 337  |  |
| 8.4.38      | Memory data path read capture ECC (DDR_CAPTURE_ECC)                  | 338  |  |
| 8.4.39      | Memory error detect (DDR_ERR_DETECT)                                 | 339  |  |
| 8.4.40      | Memory error disable (DDR_ERR_DISABLE)                               | 341  |  |
|             |                                                                      |      |  |

| Sec | tion nu    | imber Title                                                       | Page |
|-----|------------|-------------------------------------------------------------------|------|
|     | 8.4.41     | Memory error interrupt enable (DDR_ERR_INT_EN)                    | 343  |
|     | 8.4.42     | Memory error attributes capture (DDR_CAPTURE_ATTRIBUTES)          | 345  |
|     | 8.4.43     | Memory error address capture (DDR_CAPTURE_ADDRESS)                | 347  |
|     | 8.4.44     | Memory error extended address capture (DDR_CAPTURE_EXT_ADDRESS)   | 347  |
|     | 8.4.45     | Single-Bit ECC memory error management (DDR_ERR_SBE)              | 348  |
| 8.5 | Function   | nal description.                                                  | 348  |
|     | 8.5.1      | DDR SDRAM interface operation                                     | 354  |
|     |            | 8.5.1.1 Supported DDR SDRAM organizations                         | 354  |
|     | 8.5.2      | DDR SDRAM address multiplexing.                                   | 356  |
|     | 8.5.3      | JEDEC standard DDR SDRAM interface commands                       | 365  |
|     | 8.5.4      | DDR SDRAM interface timing.                                       | 367  |
|     | 8.5.5      | DDR SDRAM registered DIMM mode                                    | 370  |
|     | 8.5.6      | DDR SDRAM write timing adjustments.                               | 371  |
|     | 8.5.7      | DDR SDRAM refresh                                                 | 372  |
|     |            | 8.5.7.1 DDR SDRAM refresh timing                                  | 373  |
|     |            | 8.5.7.2 DDR SDRAM refresh and power-saving modes                  | 374  |
|     |            | 8.5.7.2.1 Self-refresh in sleep mode                              | 375  |
|     | 8.5.8      | DDR data beat ordering                                            | 376  |
|     | 8.5.9      | Page mode and logical bank retention.                             | 377  |
|     | 8.5.10     | Error checking and correcting (ECC)                               | 378  |
|     | 8.5.11     | Error management.                                                 | 379  |
| 8.6 | Initializa | ation/application information                                     | 380  |
|     | 8.6.1      | Programming differences between memory types                      | 384  |
|     | 8.6.2      | DDR SDRAM initialization sequence                                 | 389  |
| 8.7 | Using F    | Forced Self-Refresh Mode to Implement a Battery-Backed RAM System | 389  |
|     | 8.7.1      | Hardware Based Self-Refresh Scheme                                | 390  |
|     | 8.7.2      | Software Based Self-Refresh Scheme.                               | 390  |
|     | 8.7.3      | Bypassing Re-initialization During Battery-Backed Operation       | 390  |

## Chapter 9 Programmable Interrupt Controller (PIC)

| 9.1 | Introduction                       |                                                                   |     |  |  |  |
|-----|------------------------------------|-------------------------------------------------------------------|-----|--|--|--|
|     | 9.1.1                              | Overview                                                          | 393 |  |  |  |
|     | 9.1.2                              | The PIC in multiple-processor implementations                     | 396 |  |  |  |
|     | 9.1.3                              | Interrupts to the e500 processor core                             | 396 |  |  |  |
|     | 9.1.4                              | Modes of operation                                                | 397 |  |  |  |
|     |                                    | 9.1.4.1 Mixed mode (GCR[M] = 1)                                   | 397 |  |  |  |
|     |                                    | 9.1.4.2 Pass-through mode (GCR[M] = 0)                            | 397 |  |  |  |
|     | 9.1.5                              | Interrupt sources                                                 | 398 |  |  |  |
|     |                                    | 9.1.5.1 Interrupt routing-mixed mode                              | 399 |  |  |  |
|     |                                    | 9.1.5.2 Interrupt destinations                                    | 399 |  |  |  |
|     |                                    | 9.1.5.3 Internal interrupt sources                                | 400 |  |  |  |
| 9.2 | PIC external signal descriptions.  |                                                                   |     |  |  |  |
|     | 9.2.1                              | Signal overview                                                   | 402 |  |  |  |
|     | 9.2.2                              | Detailed signal descriptions.                                     | 402 |  |  |  |
| 9.3 | PIC memory map/register definition |                                                                   |     |  |  |  |
|     | 9.3.1                              | Block revision register 1 (PIC_BRR1)                              |     |  |  |  |
|     | 9.3.2                              | Block revision register 2 (PIC_BRR2)                              |     |  |  |  |
|     | 9.3.3                              | Interprocessor n dispatch register (PIC_IPIDRn)                   |     |  |  |  |
|     | 9.3.4                              | Current task priority register (PIC_CTPR)                         |     |  |  |  |
|     | 9.3.5                              | Who am I register (PIC_WHOAMI)41                                  |     |  |  |  |
|     | 9.3.6                              | Interrupt acknowledge register (PIC_IACK)41                       |     |  |  |  |
|     | 9.3.7                              | End of interrupt register (PIC_EOI)4                              |     |  |  |  |
|     | 9.3.8                              | Feature reporting register (PIC_FRR)                              |     |  |  |  |
|     | 9.3.9                              | Global configuration register (PIC_GCR)                           |     |  |  |  |
|     | 9.3.10                             | Vendor identification register (PIC_VIR)                          |     |  |  |  |
|     | 9.3.11                             | Processor core initialization register (PIC_PIR)                  | 420 |  |  |  |
|     | 9.3.12                             | Interprocessor interrupt n vector/priority register (PIC_IPIVPRn) | 421 |  |  |  |
|     |                                    |                                                                   |     |  |  |  |

| Section nur | nber Title                                                    | Page |
|-------------|---------------------------------------------------------------|------|
| 9.3.13      | Spurious vector register (PIC_SVR)                            | 422  |
| 9.3.14      | Timer frequency reporting register group X (PIC_TFRRn)        | 422  |
| 9.3.15      | Global timer n current count register group A (PIC_GTCCRAn)   | 423  |
| 9.3.16      | Global timer n base count register group A (PIC_GTBCRAn)      | 424  |
| 9.3.17      | Global timer n vector/priority register group A (PIC_GTVPRAn) | 425  |
| 9.3.18      | Global timer n destination register group A (PIC_GTDRAn)      | 426  |
| 9.3.19      | Timer control register group n (PIC_TCRn)                     | 426  |
| 9.3.20      | External interrupt summary register (PIC_ERQSR)               | 429  |
| 9.3.21      | IRQ_OUT_B summary register 0 (PIC_IRQSR0)                     | 429  |
| 9.3.22      | IRQ_OUT_B summary register 1 (PIC_IRQSR1)                     | 430  |
| 9.3.23      | IRQ_OUT_B summary register 2 (PIC_IRQSR2)                     | 430  |
| 9.3.24      | Critical interrupt summary register 0 (PIC_CISR0)             | 431  |
| 9.3.25      | Critical interrupt summary register 1 (PIC_CISR1)             | 431  |
| 9.3.26      | Critical interrupt summary register 2 (PIC_CISR2)             | 432  |
| 9.3.27      | Performance monitor n mask register 0 (PIC_PMnMR0)            | 432  |
| 9.3.28      | Performance monitor n mask register 1 (PIC_PMnMR1)            | 433  |
| 9.3.29      | Performance monitor n mask register 2 (PIC_PMnMR2)            | 433  |
| 9.3.30      | Message register n (PIC_MSGRn)                                | 434  |
| 9.3.31      | Message enable register (PIC_MER)                             | 434  |
| 9.3.32      | Message status register (PIC_MSR)                             | 435  |
| 9.3.33      | Shared message signaled interrupt register n (PIC_MSIRn)      | 435  |
| 9.3.34      | Shared message signaled interrupt status register (PIC_MSISR) | 436  |
| 9.3.35      | Shared message signaled interrupt index register (PIC_MSIIR)  | 437  |
| 9.3.36      | Global timer n current count register group B (PIC_GTCCRBn)   | 438  |
| 9.3.37      | Global timer n base count register group B (PIC_GTBCRBn)      | 439  |
| 9.3.38      | Global timer n vector/priority register group B (PIC_GTVPRBn) | 440  |
| 9.3.39      | Global timer n destination register group B (PIC_GTDRBn)      | 441  |
| 9.3.40      | Message register n (PIC_MSGRan)                               | 441  |
| 9.3.41      | Message enable register (PIC_MERa)                            | 442  |

| Sec | tion nu                 | mber        | Title                                                                | Page |  |  |
|-----|-------------------------|-------------|----------------------------------------------------------------------|------|--|--|
|     | 9.3.42                  | Message s   | status register (PIC_MSRa)                                           | 443  |  |  |
|     | 9.3.43                  | External i  | interrupt n (IRQn) vector/priority register (PIC_EIVPRn)             | 443  |  |  |
|     | 9.3.44                  | External i  | interrupt n (IRQn) destination register (PIC_EIDRn)                  | 445  |  |  |
|     | 9.3.45                  | Internal in | nterrupt n vector/priority register (PIC_IIVPRn)                     | 446  |  |  |
|     | 9.3.46                  | Internal in | nterrupt n destination register (PIC_IIDRn)                          | 447  |  |  |
|     | 9.3.47                  | Messagin    | g interrupt n (MSGn) vector/priority register (PIC_MIVPRn)           | 448  |  |  |
|     | 9.3.48                  | Messagin    | g interrupt n (MSGn) destination register (PIC_MIDRn)                | 449  |  |  |
|     | 9.3.49                  | Shared me   | essage signaled interrupt vector/priority register n (PIC_MSIVPRn)   | 450  |  |  |
|     | 9.3.50                  | Shared me   | essage signaled interrupt destination register n (PIC_MSIDRn)        | 451  |  |  |
|     | 9.3.51                  | Processor   | core 0 interprocessor n dispatch register (PIC_IPIDR_CPU0n)          | 452  |  |  |
|     | 9.3.52                  | Processor   | core current task priority register 0 Processor core (PIC_CTPR_CPU0) | 452  |  |  |
|     | 9.3.53                  | Processor   | core 0 who am I register (PIC_WHOAMI_CPU0)                           | 453  |  |  |
|     | 9.3.54                  | Processor   | core 0 interrupt acknowledge register (PIC_IACK_CPU0)                | 454  |  |  |
|     | 9.3.55                  | Processor   | core 0 end of interrupt register (PIC_EOI_CPU0)                      | 455  |  |  |
|     | 9.3.56                  | Processor   | core 1 interprocessor n dispatch register (PIC_IPIDR_CPU1n)          | 456  |  |  |
|     | 9.3.57                  | Processor   | core 1 current task priority register (PIC_CTPR_CPU1)                | 456  |  |  |
|     | 9.3.58                  | Processor   | core 1 who am I register (PIC_WHOAMI_CPU1)                           | 457  |  |  |
|     | 9.3.59                  | Processor   | core 1 interrupt acknowledge register (PIC_IACK_CPU1)                | 458  |  |  |
|     | 9.3.60                  | Processor   | core 1 end of interrupt register (PIC_EOI_CPU1)                      | 459  |  |  |
| 9.4 | Functional description. |             |                                                                      |      |  |  |
|     | 9.4.1                   | Programn    | ning model considerations                                            | 459  |  |  |
|     |                         | 9.4.1.1     | Global registers                                                     | 459  |  |  |
|     |                         | 9.4.1.2     | Global timer registers                                               | 460  |  |  |
|     |                         | 9.4.1.3     | IRQ_OUT_B and critical interrupt summary registers                   | 460  |  |  |
|     |                         | 9.4.1.4     | Performance monitor mask registers (PMMRs)                           | 461  |  |  |
|     |                         | 9.4.1.5     | Message registers                                                    | 461  |  |  |
|     |                         | 9.4.1.6     | Shared message signaled registers                                    | 461  |  |  |
|     |                         | 9.4.1.7     | Interrupt source configuration registers                             | 461  |  |  |
|     |                         | 9.4.1.8     | Per-CPU (private access) registers                                   | 463  |  |  |
|     |                         |             |                                                                      |      |  |  |

| Sec  | tion nu   | mber          |                 | Title                          | Page |
|------|-----------|---------------|-----------------|--------------------------------|------|
|      | 9.4.2     | Flow of in    | nterrupt contro | ol                             | 465  |
|      |           | 9.4.2.1       | Interrupts 1    | routed to cint or IRQ_OUT_B    |      |
|      |           | 9.4.2.2       | Interrupts 1    | routed to int                  | 466  |
|      |           |               | 9.4.2.2.1       | Interrupt source priority      | 468  |
|      |           |               | 9.4.2.2.2       | Interrupt acknowledge          | 468  |
|      |           |               | 9.4.2.2.3       | Spurious vector generation     | 469  |
|      |           |               | 9.4.2.2.4       | Nesting of interrupts          | 469  |
|      | 9.4.3     | Interproce    | essor interrupt | ts                             | 470  |
|      | 9.4.4     | Message       | interrupts      |                                | 470  |
|      | 9.4.5     | Shared m      | essage signale  | ed interrupts                  | 470  |
|      | 9.4.6     | PCI Expr      | 471             |                                |      |
|      | 9.4.7     | Global tir    | ners            |                                | 472  |
|      | 9.4.8     | Resets        |                 |                                |      |
|      | 9.4.9     | Resetting     | the PIC         |                                | 473  |
|      |           | 9.4.9.1       | Processor o     | core initialization            | 473  |
| 9.5  | Initializ | ation/applica | ation informat  | ion                            | 473  |
|      | 9.5.1     | Programn      | ning guideline  | es                             | 473  |
|      |           | 9.5.1.1       | PIC registe     | ers                            | 474  |
|      |           | 9.5.1.2       | Changing i      | interrupt source configuration | 475  |
|      |           |               |                 | Chapter 10<br>I2C Interfaces   |      |
| 10.1 | Overvie   | w             |                 |                                | 477  |
| 10.2 | Introduc  | ction to I2C. |                 |                                | 477  |
|      | 10.2.1    | What is th    | ne I2C module   | e?                             | 477  |
|      | 10.2.2    | I2C modu      | ıle block diagı | ram                            | 478  |
|      | 10.2.3    | Features .    |                 |                                | 478  |
|      | 10.2.4    | Advantag      | ges of the I2C  | bus                            | 479  |
|      | 10.2.5    | Modes of      | operation       |                                | 479  |
|      | 10.2.6    | I2C-speci     | fic conditions  | S                              | 479  |
|      |           |               |                 |                                |      |

| Sec  | Section number |                |                   | Title                                         | Page |
|------|----------------|----------------|-------------------|-----------------------------------------------|------|
| 10.3 | I2C exte       | ernal signal d | 480               |                                               |      |
|      | 10.3.1         | Signal ove     | erview            |                                               | 480  |
|      | 10.3.2         | Detailed s     | ignal descriptio  | ns                                            | 480  |
| 10.4 | I2C mer        | nory map/re    | gister definition |                                               | 481  |
|      | 10.4.1         | I2C addre      | ss register (I2C. | x_I2CADR)                                     | 482  |
|      | 10.4.2         | I2C freque     | ency divider reg  | gister (I2Cx_I2CFDR)                          | 483  |
|      | 10.4.3         | I2C contro     | ol register (I2C) | c_I2CCR)                                      | 485  |
|      | 10.4.4         | I2C status     | register (I2Cx_   | _I2CSR)                                       | 486  |
|      | 10.4.5         | I2C data r     | egister (I2Cx_I   | 2CDR)                                         | 487  |
|      | 10.4.6         | I2C digita     | l filter sampling | g rate register (I2Cx_I2CDFSRR)               | 488  |
| 10.5 | Function       | 488            |                   |                                               |      |
|      | 10.5.1         | Transactio     | on protocol       |                                               | 488  |
|      |                | 10.5.1.1       | START cond        | lition                                        | 489  |
|      |                | 10.5.1.2       | Slave address     | s transmission                                | 489  |
|      |                | 10.5.1.3       | Repeated ST       | ART condition                                 | 490  |
|      |                | 10.5.1.4       | STOP condit       | ion                                           | 491  |
|      |                | 10.5.1.5       | Protocol imp      | lementation details                           | 491  |
|      |                |                | 10.5.1.5.1        | Transaction monitoring-implementation details | 491  |
|      |                |                | 10.5.1.5.2        | Control transfer-implementation details.      | 491  |
|      |                | 10.5.1.6       | Address com       | pare-implementation details.                  | 492  |
|      | 10.5.2         | Arbitration    | n procedure       |                                               | 493  |
|      |                | 10.5.2.1       | Arbitration c     | ontrol                                        | 493  |
|      | 10.5.3         | Handshak       |                   | 494                                           |      |
|      | 10.5.4         | Clock con      | trol              |                                               | 494  |
|      |                | 10.5.4.1       | Clock synchi      | onization                                     | 494  |
|      |                | 10.5.4.2       | Input synchro     | onization and digital filter                  | 495  |
|      |                |                | 10.5.4.2.1        | Input signal synchronization                  | 495  |
|      |                |                | 10.5.4.2.2        | Filtering of SCL and SDA lines                | 495  |
|      |                | 10.5.4.3       | Clock stretch     | ing                                           | 495  |
|      |                |                |                   |                                               |      |

| Sec  | tion nu    | mber Title                                             | Page |  |  |  |
|------|------------|--------------------------------------------------------|------|--|--|--|
|      | 10.5.5     | Boot sequencer mode                                    | 496  |  |  |  |
|      |            | 10.5.5.1 EEPROM calling address                        | 497  |  |  |  |
|      |            | 10.5.5.2 EEPROM data format                            | 497  |  |  |  |
| 10.6 | Initializa | ation/application information                          | 500  |  |  |  |
|      | 10.6.1     | Initialization sequence                                | 500  |  |  |  |
|      | 10.6.2     | Generation of START                                    | 501  |  |  |  |
|      | 10.6.3     | Post-transfer software response.                       | 501  |  |  |  |
|      | 10.6.4     | Generation of STOP                                     | 502  |  |  |  |
|      | 10.6.5     | Generation of repeated START                           | 502  |  |  |  |
|      | 10.6.6     | Generation of SCL when SDA low                         | 502  |  |  |  |
|      | 10.6.7     | Slave mode interrupt service routine                   | 503  |  |  |  |
|      |            | 10.6.7.1 Slave transmitter and received acknowledge    | 503  |  |  |  |
|      |            | 10.6.7.2 Loss of arbitration and forcing of slave mode | 503  |  |  |  |
|      | 10.6.8     | Interrupt service routine flowchart                    | 504  |  |  |  |
|      |            | Chapter 11 DUART                                       |      |  |  |  |
| 11.1 | Introduc   | ction                                                  | 507  |  |  |  |
|      | 11.1.1     | Overview                                               | 507  |  |  |  |
|      |            | 11.1.1.1 Features                                      | 508  |  |  |  |
|      |            | 11.1.1.2 Modes of operation                            | 509  |  |  |  |
| 11.2 | DUART      | Γ external signal descriptions                         | 509  |  |  |  |
| 11.3 | DUART      | Γ memory map/register definition                       | 510  |  |  |  |
|      | 11.3.1     | Receiver Buffer Registers (DUART_URBRn)                | 512  |  |  |  |
|      | 11.3.2     | Transmitter Holding Registers (DUART_UTHRn)            | 512  |  |  |  |
|      | 11.3.3     | Divisor Least Significant Byte Registers (DUART_UDLBn) | 513  |  |  |  |
|      | 11.3.4     | Divisor Most Significant Byte Registers (DUART_UDMBn)  | 514  |  |  |  |
|      | 11.3.5     | Interrupt Enable Register (DUART_UIERn)                |      |  |  |  |
|      | 11.3.6     | Interrupt ID Registers (DUART_UIIRn)                   | 516  |  |  |  |
|      | 11.3.7     | FIFO Control Registers (DUART_UFCRn)                   | 517  |  |  |  |
|      |            |                                                        |      |  |  |  |

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

| Section number |          |                | Title                                           | Page |  |
|----------------|----------|----------------|-------------------------------------------------|------|--|
|                | 11.3.8   | Alternate      | Function Registers (DUART_UAFRn)                | 519  |  |
|                | 11.3.9   | Line Cont      | trol Registers (DUART_ULCRn)                    | 519  |  |
|                | 11.3.10  | Modem C        | Control Registers (DUART_UMCRn)                 | 521  |  |
|                | 11.3.11  | Line Statu     | as Registers (DUART_ULSRn)                      | 522  |  |
|                | 11.3.12  | Modem S        | tatus Registers (DUART_UMSRn)                   | 523  |  |
|                | 11.3.13  | Scratch R      | egisters (DUART_USCRn)                          | 524  |  |
|                | 11.3.14  | DMA Stat       | tus Registers (DUART_UDSRn)                     | 524  |  |
| 11.4           | Function | al description | on                                              | 526  |  |
|                | 11.4.1   | Serial inte    | erface                                          | 526  |  |
|                |          | 11.4.1.1       | START bit                                       | 527  |  |
|                |          | 11.4.1.2       | Data transfer                                   | 527  |  |
|                |          | 11.4.1.3       | Parity bit                                      | 528  |  |
|                |          | 11.4.1.4       | STOP bit                                        | 528  |  |
|                | 11.4.2   | Baud-rate      | generator logic                                 | 528  |  |
|                | 11.4.3   | Local loop     | pback mode                                      | 529  |  |
|                | 11.4.4   | Errors         |                                                 | 529  |  |
|                |          | 11.4.4.1       | Framing error                                   | 529  |  |
|                |          | 11.4.4.2       | Parity error                                    | 530  |  |
|                |          | 11.4.4.3       | Overrun error.                                  | 530  |  |
|                | 11.4.5   | FIFO mod       | le                                              | 530  |  |
|                |          | 11.4.5.1       | FIFO interrupts                                 | 530  |  |
|                |          | 11.4.5.2       | DMA mode select                                 | 531  |  |
|                |          | 11.4.5.3       | Interrupt control logic                         | 531  |  |
| 11.5           | DUART    | initializatio  | on/application information                      | 532  |  |
|                |          |                | Chapter 12 Enhanced local bus controller (eLBC) |      |  |
| 12.1           | eLBC in  | troduction     |                                                 | 533  |  |
|                | 12.1.1   | Overview       |                                                 | 534  |  |
|                | 12.1.2   | Features       |                                                 | 535  |  |
|                |          |                |                                                 |      |  |

| Sec  | tion nui | mber Title                                           | Page |  |
|------|----------|------------------------------------------------------|------|--|
|      | 12.1.3   | Modes of operation                                   | 536  |  |
|      |          | 12.1.3.1 eLBC bus clock and clock ratios             | 536  |  |
|      |          | 12.1.3.2 Source ID debug mode                        | 537  |  |
| 12.2 | eLBC ex  | ternal signal descriptions                           | 537  |  |
| 12.3 | Enhance  | d Local Bus Controller (eLBC) Memory Map             | 540  |  |
|      | 12.3.1   | Base register 0 (eLBC_BR0)                           | 544  |  |
|      | 12.3.2   | Options register 0 layout for GPCM Mode (eLBC_ORg0)  | 546  |  |
|      | 12.3.3   | Options register 0 layout for FCM Mode (eLBC_ORf0)   | 549  |  |
|      | 12.3.4   | Options register 0 layout for UPM Mode (eLBC_ORu0)   | 553  |  |
|      | 12.3.5   | Base register n (eLBC_BRn)                           | 557  |  |
|      | 12.3.6   | Options register n layout for GPCM Mode (eLBC_ORgn)  | 558  |  |
|      | 12.3.7   | Options register n layout for FCM Mode (eLBC_ORfn)   | 562  |  |
|      | 12.3.8   | Options register n layout for UPM Mode (eLBC_ORun)   | 566  |  |
|      | 12.3.9   | UPM address register (eLBC_MAR)                      | 568  |  |
|      | 12.3.10  | UPMn mode register (eLBC_MnMR)                       | 569  |  |
|      | 12.3.11  | Memory refresh timer prescaler register (eLBC_MRTPR) | 572  |  |
|      | 12.3.12  | UPM data register (eLBC_MDRu).                       | 572  |  |
|      | 12.3.13  | FCM data register (eLBC_MDRf)                        | 573  |  |
|      | 12.3.14  | Special operation initiation register (eLBC_LSOR)    | 573  |  |
|      | 12.3.15  | UPM refresh timer (eLBC_LURT)                        | 574  |  |
|      | 12.3.16  | Transfer error status register (eLBC_LTESR)          | 575  |  |
|      | 12.3.17  | Transfer error disable register (eLBC_LTEDR)         | 577  |  |
|      | 12.3.18  | Transfer error interrupt register (eLBC_LTEIR)       | 578  |  |
|      | 12.3.19  | Transfer error attributes register (eLBC_LTEATR)     | 579  |  |
|      | 12.3.20  | Transfer error address register (eLBC_LTEAR)         | 580  |  |
|      | 12.3.21  | Transfer error ECC register (eLBC_LTECCR)            | 581  |  |
|      | 12.3.22  | Configuration register (eLBC_LBCR)                   | 582  |  |
|      | 12.3.23  | Clock ratio register (eLBC_LCRR)                     | 584  |  |
|      | 12.3.24  | Flash mode register (eLBC_FMR)                       | 585  |  |
|      |          |                                                      |      |  |

| Section number |                | Title                                                              | Page |
|----------------|----------------|--------------------------------------------------------------------|------|
| 12.3.25        | 5 Flash inst   | ruction register (eLBC_FIR)                                        | 587  |
| 12.3.26        | 5 Flash com    | nmand register (eLBC_FCR)                                          | 589  |
| 12.3.27        | 7 Flash bloo   | ck address register (eLBC_FBAR)                                    | 589  |
| 12.3.28        | 3 Flash pag    | e address register [Large Page Device (ORx[PGS] = 1)] (eLBC_FPARI) | 590  |
| 12.3.29        | Flash pag      | e address register [Small Page Device (ORx[PGS] = 0)] (eLBC_FPARs) | 591  |
| 12.3.30        | ) Flash byte   | e count register (eLBC_FBCR)                                       | 592  |
| 12.3.31        | I Flash ECO    | C block n registers (eLBC_FECCn)                                   | 593  |
| 12.4 eLBC      | functional des | scription                                                          | 593  |
| 12.4.1         | Basic arcl     | hitecture                                                          | 595  |
|                | 12.4.1.1       | Address and address space checking                                 | 595  |
|                | 12.4.1.2       | External address latch enable signal (LALE)                        | 595  |
|                | 12.4.1.3       | Data transfer acknowledge (TA)                                     | 597  |
|                | 12.4.1.4       | Data buffer control (LBCTL)                                        | 598  |
|                | 12.4.1.5       | Parity generation and checking (LDP)                               | 599  |
|                | 12.4.1.6       | Bus monitor                                                        | 599  |
|                | 12.4.1.7       | PLL Bypass mode                                                    | 600  |
| 12.4.2         | General-p      | purpose chip-select machine (GPCM)                                 | 600  |
|                | 12.4.2.1       | GPCM read signal timing                                            | 601  |
|                | 12.4.2.2       | GPCM write signal timing                                           | 603  |
|                | 12.4.2.3       | Chip-select assertion timing.                                      | 605  |
|                |                | 12.4.2.3.1 Programmable wait state configuration                   | 605  |
|                |                | 12.4.2.3.2 Chip-select and write enable negation timing            | 606  |
|                |                | 12.4.2.3.3 Relaxed timing                                          | 607  |
|                |                | 12.4.2.3.4 Output enable (LOE_B) timing                            | 611  |
|                |                | 12.4.2.3.5 Extended hold time on read accesses-GPCM                | 611  |
|                | 12.4.2.4       | External access termination (LGTA_B)                               | 612  |
|                | 12.4.2.5       | GPCM boot chip-select operation                                    | 613  |

| Section nu | mber                        |              | Title                                                            | Page |  |
|------------|-----------------------------|--------------|------------------------------------------------------------------|------|--|
| 12.4.3     | Flash control machine (FCM) |              |                                                                  |      |  |
|            | 12.4.3.1                    | FCM buffer   | RAM                                                              | 616  |  |
|            |                             | 12.4.3.1.1   | Buffer layout and page mapping for small-page NAND flash devices | 617  |  |
|            |                             | 12.4.3.1.2   | Buffer layout and page mapping for large-page NAND flash devices | 618  |  |
|            |                             | 12.4.3.1.3   | Error correcting codes and the spare region                      | 619  |  |
|            | 12.4.3.2                    | Programmir   | g FCM                                                            | 621  |  |
|            |                             | 12.4.3.2.1   | FCM command instructions                                         | 622  |  |
|            |                             | 12.4.3.2.2   | FCM no-operation instruction                                     | 623  |  |
|            |                             | 12.4.3.2.3   | FCM address instructions                                         | 623  |  |
|            |                             | 12.4.3.2.4   | FCM data read instructions                                       | 624  |  |
|            |                             | 12.4.3.2.5   | FCM data write instructions                                      | 624  |  |
|            | 12.4.3.3                    | FCM signal   | timing                                                           | 625  |  |
|            |                             | 12.4.3.3.1   | FCM chip-select timing                                           | 625  |  |
|            |                             | 12.4.3.3.2   | FCM command, address, and write data timing                      | 625  |  |
|            |                             | 12.4.3.3.3   | FCM ready/busy timing                                            | 627  |  |
|            |                             | 12.4.3.3.4   | FCM read data timing                                             | 628  |  |
|            |                             | 12.4.3.3.5   | FCM extended read hold timing                                    | 629  |  |
|            | 12.4.3.4                    | FCM boot c   | hip-select operation                                             | 630  |  |
|            |                             | 12.4.3.4.1   | FCM bank 0 reset initialization                                  | 631  |  |
|            |                             | 12.4.3.4.2   | Boot block loading into the FCM buffer RAM                       | 631  |  |
| 12.4.4     | User-prog                   | rammable mac | hines (UPMs)                                                     | 633  |  |
|            | 12.4.4.1                    | UPM reques   | sts                                                              | 634  |  |
|            |                             | 12.4.4.1.1   | Memory access requests                                           | 635  |  |
|            |                             | 12.4.4.1.2   | UPM refresh timer requests                                       | 636  |  |
|            |                             | 12.4.4.1.3   | Software requests-RUN command.                                   | 636  |  |
|            |                             | 12.4.4.1.4   | Exception requests                                               | 637  |  |
|            | 12.4.4.2                    | Programmin   | g the UPMs                                                       | 637  |  |
|            |                             | 12.4.4.2.1   | UPM programming example (two sequential writes to the RAM array) | 638  |  |
|            |                             | 12.4.4.2.2   | UPM programming example (two sequential reads from the RAM array | )639 |  |

| Section number |         | Title           |                  |                                                                  |     |
|----------------|---------|-----------------|------------------|------------------------------------------------------------------|-----|
|                |         | 12.4.4.3        | UPM signal       | timing                                                           | 640 |
|                |         | 12.4.4.4        | RAM array        |                                                                  | 640 |
|                |         |                 | 12.4.4.4.1       | RAM words                                                        | 641 |
|                |         |                 | 12.4.4.4.2       | Chip-select signal timing (CSTn)                                 | 645 |
|                |         |                 | 12.4.4.4.3       | Byte select signal timing (BSTn)                                 | 646 |
|                |         |                 | 12.4.4.4         | General-purpose signals (GnTn, GOn)                              | 647 |
|                |         |                 | 12.4.4.4.5       | Loop control (LOOP)                                              | 647 |
|                |         |                 | 12.4.4.4.6       | Repeat execution of current RAM word (REDO)                      | 648 |
|                |         |                 | 12.4.4.4.7       | Address multiplexing (AMX)                                       | 648 |
|                |         |                 | 12.4.4.4.8       | Data valid and data sample control (UTA)                         | 650 |
|                |         |                 | 12.4.4.4.9       | LGPL[0:5] signal negation (LAST)                                 | 651 |
|                |         |                 | 12.4.4.4.10      | Wait mechanism (WAEN)                                            | 651 |
|                |         | 12.4.4.5        | Extended ho      | ld time on read accesses-UPM                                     | 653 |
| 12.5           | eLBC ir | nitialization/a | application info | rmation                                                          | 653 |
|                | 12.5.1  | Interfacing     | g to peripherals | in different address modes                                       | 653 |
|                |         | 12.5.1.1        | Non-multiple     | exed address and data buses                                      | 653 |
|                |         | 12.5.1.2        | Multiplexed      | address and data to save maximum pins in 8- to 16-bit addressing | 654 |
|                |         | 12.5.1.3        | Peripheral hi    | erarchy on the local bus for high bus speeds                     | 654 |
|                |         | 12.5.1.4        | GPCM timir       | ngs                                                              | 655 |
|                | 12.5.2  | Bus turnar      | ound             |                                                                  | 656 |
|                |         | 12.5.2.1        | Address pha      | se after previous read                                           | 657 |
|                |         | 12.5.2.2        | Read data ph     | nase after address phase                                         | 657 |
|                |         | 12.5.2.3        | Read-modify      | y-write cycle for parity protected memory banks                  | 657 |
|                |         | 12.5.2.4        | UPM cycles       | with additional address phases                                   | 658 |
|                | 12.5.3  | Interface t     | o different port | size devices                                                     | 658 |
|                | 12.5.4  | Command         | l sequence exar  | nples for NAND flash EEPROM                                      | 659 |
|                |         | 12.5.4.1        | NAND flash       | soft reset command sequence example                              | 659 |
|                |         | 12.5.4.2        | NAND flash       | read status command sequence example                             | 660 |
|                |         | 12.5.4.3        | NAND flash       | read identification command sequence example                     | 661 |
|                |         |                 |                  |                                                                  |     |

| Section number |         | mber         | Title                                                         | Page |  |
|----------------|---------|--------------|---------------------------------------------------------------|------|--|
|                |         | 12.5.4.4     | NAND flash page read command sequence example                 | 661  |  |
|                |         | 12.5.4.5     | NAND flash block erase command sequence example               | 662  |  |
|                |         | 12.5.4.6     | NAND flash program command sequence example                   | 663  |  |
|                | 12.5.5  | Interfacing  | g to fast-page mode DRAM using UPM                            | 664  |  |
|                | 12.5.6  | Interfacing  | g to ZBT SRAM using UPM                                       | 673  |  |
|                |         |              | Chapter 13 DMA Controller                                     |      |  |
| 13.1           | DMA ov  | erview       |                                                               | 677  |  |
|                | 13.1.1  | DMA feat     | tures summary                                                 | 678  |  |
|                | 13.1.2  | DMA mod      | des of operation                                              | 678  |  |
| 13.2           | DMA ex  | ternal signa | l description                                                 | 681  |  |
|                | 13.2.1  | Signal ove   | erview                                                        | 681  |  |
|                | 13.2.2  | DMA sign     | nal descriptions                                              | 682  |  |
| 13.3           | DMA co  | ntroller mer | mory map                                                      | 682  |  |
|                | 13.3.1  | DMA mod      | de register (DMA_MRn)                                         | 686  |  |
|                | 13.3.2  | DMA stat     | us register (DMA_SRn)                                         | 690  |  |
|                | 13.3.3  | DMA curi     | rent link descriptor extended address register (DMA_ECLNDARn) | 691  |  |
|                | 13.3.4  | DMA curi     | rent link descriptor address register (DMA_CLNDARn)           | 692  |  |
|                | 13.3.5  | DMA sou      | rce attributes register (DMA_SATRn)                           | 694  |  |
|                | 13.3.6  | DMA sou      | rce address register (DMA_SARn)                               | 695  |  |
|                | 13.3.7  | DMA dest     | tination attributes register (DMA_DATRn)                      | 695  |  |
|                | 13.3.8  | DMA dest     | tination address register (DMA_DARn)                          | 696  |  |
|                | 13.3.9  | DMA byte     | e count register (DMA_BCRn)                                   | 697  |  |
|                | 13.3.10 | DMA exte     | ended next link descriptor address register (DMA_ENLNDARn)    | 697  |  |
|                | 13.3.11 | DMA nex      | t link descriptor address register (DMA_NLNDARn)              | 698  |  |
|                | 13.3.12 | DMA exte     | ended current list descriptor address register (DMA_ECLSDARn) | 699  |  |
|                | 13.3.13 | DMA curi     | rent list descriptor address register (DMA_CLSDARn)           | 700  |  |
|                | 13.3.14 | DMA exte     | ended next list descriptor address register (DMA_ENLSDARn)    | 701  |  |
|                | 13.3.15 | DMA nex      | t list descriptor address register (DMA_NLSDARn)              | 701  |  |
|                |         |              |                                                               |      |  |

| Section numb |         | nber         | er Title           |                                            |     |  |  |
|--------------|---------|--------------|--------------------|--------------------------------------------|-----|--|--|
|              | 13.3.16 | DMA sou      | rce stride regis   | ce stride register (DMA_SSRn)              |     |  |  |
|              | 13.3.17 | DMA des      | tination stride    | register (DMA_DSRn)                        | 703 |  |  |
|              | 13.3.18 | DMA gen      | eral status regi   | ster (DMA_DGSR)                            | 704 |  |  |
| 13.4         | DMA fu  | nctional des | cription           |                                            | 707 |  |  |
|              | 13.4.1  | DMA cha      | nnel operation     |                                            | 707 |  |  |
|              |         | 13.4.1.1     | Source/desti       | ination transaction size calculations      | 708 |  |  |
|              |         | 13.4.1.2     | Basic DMA          | mode transfer.                             | 710 |  |  |
|              |         |              | 13.4.1.2.1         | Basic direct mode                          | 710 |  |  |
|              |         |              | 13.4.1.2.2         | Basic, direct, single-write start mode     | 710 |  |  |
|              |         |              | 13.4.1.2.3         | Basic chaining mode                        | 711 |  |  |
|              |         |              | 13.4.1.2.4         | Basic chaining, single-write start mode    | 712 |  |  |
|              |         | 13.4.1.3     | Extended D         | MA mode transfer                           | 713 |  |  |
|              |         |              | 13.4.1.3.1         | Extended direct mode                       | 713 |  |  |
|              |         |              | 13.4.1.3.2         | Extended direct, single-write start mode   | 713 |  |  |
|              |         |              | 13.4.1.3.3         | Extended chaining mode                     | 713 |  |  |
|              |         |              | 13.4.1.3.4         | Extended chaining, single-write start mode | 714 |  |  |
|              |         | 13.4.1.4     | External cor       | ntrol mode transfer                        | 715 |  |  |
|              |         | 13.4.1.5     | Channel cor        | ntinue mode for cascading transfer chains  | 716 |  |  |
|              |         |              | 13.4.1.5.1         | Basic mode                                 | 717 |  |  |
|              |         |              | 13.4.1.5.2         | Extended mode                              | 717 |  |  |
|              |         | 13.4.1.6     | Channel abo        | ort                                        | 717 |  |  |
|              |         | 13.4.1.7     | Bandwidth o        | control                                    | 717 |  |  |
|              |         | 13.4.1.8     | Channel stat       | te                                         | 718 |  |  |
|              |         | 13.4.1.9     | Illustration of    | of stride size and stride distance         | 718 |  |  |
|              | 13.4.2  | DMA tran     | sfer interfaces    |                                            | 719 |  |  |
|              | 13.4.3  | DMA erro     | ors                |                                            | 719 |  |  |
|              | 13.4.4  | DMA des      | criptors           |                                            | 720 |  |  |
|              | 13.4.5  | DMA con      | troller limitation | ons and restrictions.                      | 723 |  |  |
|              |         |              |                    |                                            |     |  |  |

| Section number |          | mber                                | Title                                                              | Page |  |  |
|----------------|----------|-------------------------------------|--------------------------------------------------------------------|------|--|--|
| 13.5           | DMA sy   | stem consid                         | n considerations                                                   |      |  |  |
|                | 13.5.1   | Unusual I                           | DMA scenarios                                                      | 725  |  |  |
|                |          | 13.5.1.1                            | DMA to core                                                        | 725  |  |  |
|                |          | 13.5.1.2                            | DMA to QUICC Engine block                                          | 725  |  |  |
|                |          | 13.5.1.3                            | DMA to configuration, control, and status registers (CCSR)         | 726  |  |  |
|                |          | 13.5.1.4                            | DMA to I2C                                                         | 726  |  |  |
|                |          | 13.5.1.5                            | DMA to DUART                                                       | 726  |  |  |
|                |          |                                     | Chapter 14 PCI Express Interface Controller                        |      |  |  |
| 14.1           | Introduc | tion                                |                                                                    | 727  |  |  |
|                | 14.1.1   | Outbound                            | l transactions                                                     | 729  |  |  |
|                | 14.1.2   | Inbound to                          | ransactions                                                        | 730  |  |  |
| 14.2           | PCI Exp  | ress features                       | s summary                                                          | 731  |  |  |
| 14.3           | PCI Exp  | oress modes                         | of operation                                                       | 731  |  |  |
|                | 14.3.1   | Root com                            | plex/endpoint modes                                                | 732  |  |  |
|                | 14.3.2   | Link widt                           | ih                                                                 | 732  |  |  |
| 14.4           | PCI Exp  | oress signal d                      | descriptions                                                       | 732  |  |  |
| 14.5           | Memory   | map/registe                         | er overview                                                        | 733  |  |  |
| 14.6           | PCI Exp  | PCI Express memory-mapped registers |                                                                    |      |  |  |
|                | 14.6.1   | PCI Expre                           | ess configuration address register (PEXx_PEX_CONFIG_ADDR)          | 739  |  |  |
|                | 14.6.2   | PCI Expre                           | ess configuration data register (PEXx_PEX_CONFIG_DATA)             | 740  |  |  |
|                | 14.6.3   | PCI Expre                           | ess outbound completion timeout register (PEXx_PEX_OTB_CPL_TOR)    | 740  |  |  |
|                | 14.6.4   | PCI Expre                           | ess configuration retry timeout register (PEXx_PEX_CONF_RTY_TOR)   | 741  |  |  |
|                | 14.6.5   | PCI Expre                           | ess configuration register (PEXx_PEX_CONFIG)                       | 742  |  |  |
|                | 14.6.6   | PCI Expre                           | ess PME & message detect register (PEXx_PEX_PME_MES_DR)            | 743  |  |  |
|                | 14.6.7   | PCI Expre                           | ess PME & message disable register (PEXx_PEX_PME_MES_DISR)         | 746  |  |  |
|                | 14.6.8   | PCI Expre                           | ess PME & message interrupt enable register (PEXx_PEX_PME_MES_IER) | 748  |  |  |
|                | 14.6.9   | PCI Expre                           | ess power management command register (PEXx_PEX_PMCR)              | 750  |  |  |
|                | 14.6.10  | IP block r                          | revision register 1 (PEXx_PEX_IP_BLK_REV1)                         | 751  |  |  |

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

| Sec  | tion nui | nber                                                                          | Page |
|------|----------|-------------------------------------------------------------------------------|------|
|      | 14.6.11  | IP block revision register 2 (PEXx_PEX_IP_BLK_REV2)                           | 751  |
|      | 14.6.12  | PCI Express outbound translation address register n (PEXx_PEXOTARn)           | 752  |
|      | 14.6.13  | PCI Express outbound translation extended address register n (PEXx_PEXOTEARn) | 752  |
|      | 14.6.14  | PCI Express outbound window attributes register n (PEXx_PEXOWAR0)             | 754  |
|      | 14.6.15  | PCI Express outbound window base address register n (PEXx_PEXOWBARn)          | 756  |
|      | 14.6.16  | PCI Express outbound window attributes register n (PEXx_PEXOWARn)             | 757  |
|      | 14.6.17  | PCI Express outbound window attributes register 3 (PEXx_PEXOWAR3)             | 760  |
|      | 14.6.18  | PCI Express outbound window attributes register 4 (PEXx_PEXOWAR4)             | 762  |
|      | 14.6.19  | PCI Express inbound translation address register n (PEXx_PEXITARn)            | 764  |
|      | 14.6.20  | PCI Express inbound window base address register n (PEXx_PEXIWBARn)           | 765  |
|      | 14.6.21  | PCI Express inbound window base extended address register n (PEXx_PEXIWBEARn) | 766  |
|      | 14.6.22  | PCI Express inbound window attributes register n (PEXx_PEXIWARn)              | 767  |
|      | 14.6.23  | PCI Express error detect register (PEXx_PEX_ERR_DR)                           | 770  |
|      | 14.6.24  | PCI Express error interrupt enable register (PEXx_PEX_ERR_EN)                 | 773  |
|      | 14.6.25  | PCI Express error disable register (PEXx_PEX_ERR_DISR)                        | 776  |
|      | 14.6.26  | PCI Express error capture status register (PEXx_PEX_ERR_CAP_STAT)             | 778  |
|      | 14.6.27  | PCI Express error capture register n (PEXx_PEX_ERR_CAP_Rn)                    | 779  |
| 14.7 | PCI Exp  | ress configuration-space registers                                            | 780  |
|      | 14.7.1   | PCI compatible configuration headers.                                         | 780  |
| 14.8 | Type 0 c | onfiguration header registers                                                 | 781  |
|      | 14.8.1   | PCI Express Vendor ID Register (Vendor_ID_Register)                           | 783  |
|      | 14.8.2   | PCI Express Device ID Register (Device_ID_Register)                           | 783  |
|      | 14.8.3   | PCI Express Command Register (Command_Register)                               | 784  |
|      | 14.8.4   | PCI Express Status Register (Status_Register)                                 | 786  |
|      | 14.8.5   | PCI Express Revision ID Register (Revision_ID_Register)                       | 787  |
|      | 14.8.6   | PCI Express Class Code Register (Class_Code_Register)                         | 787  |
|      | 14.8.7   | PCI Express Cache Line Size Register (Cache_Line_Size_Register)               | 788  |
|      | 14.8.8   | PCI Express Latency Timer Register (Latency_Timer_Register)                   | 789  |
|      | 14.8.9   | PCI Express Header Type Register (Header_Type_Register)                       | 789  |
|      |          |                                                                               |      |

| Sec  | tion nui | mber Title                                                                                        | Page        |
|------|----------|---------------------------------------------------------------------------------------------------|-------------|
|      | 14.8.10  | PCI Express Base Address Register 0 (PEXCSRBAR)                                                   | 790         |
|      | 14.8.11  | PCI Express Base Address Register 1 (BAR1)                                                        | 791         |
|      | 14.8.12  | PCI Express Base Address Register 2,4 (BARn)                                                      | 792         |
|      | 14.8.13  | PCI Express Base Address Register 3,5 (BARn)                                                      | 794         |
|      | 14.8.14  | PCI Express Subsystem Vendor ID Register (Subsystem_Vendor_ID_Register)                           | 794         |
|      | 14.8.15  | PCI Express Subsystem ID Register (Subsystem_ID_Register)                                         | 795         |
|      | 14.8.16  | Capabilities Pointer Register (Capabilities_Pointer_Register)                                     | 796         |
|      | 14.8.17  | PCI Express Interrupt Line Register (Interrupt_Line_Register)                                     | 796         |
|      | 14.8.18  | PCI Express Interrupt Pin Register (Interrupt_Pin_Register)                                       | 797         |
|      | 14.8.19  | PCI Express Minimum Grant Register (Minimum_Grant_Register)                                       | 797         |
|      | 14.8.20  | PCI Express Maximum Latency Register (Maximum_Latency_Register)                                   | 798         |
| 14.9 | Type 1 c | configuration header registers                                                                    | 798         |
|      | 14.9.1   | PCI Express Base Address Register 0 (PEXCSRBAR)                                                   | 799         |
|      | 14.9.2   | PCI Express Primary Bus Number Register (Primary_Bus_Number_Register)                             | 801         |
|      | 14.9.3   | PCI Express Secondary Bus Number Register (Secondary_Bus_Number_Register)                         | 801         |
|      | 14.9.4   | PCI Express Subordinate Bus Number Register (Subordinate_Bus_Number_Register)                     | 801         |
|      | 14.9.5   | PCI Express I/O Base Register (IO_Base_Register)                                                  | 802         |
|      | 14.9.6   | PCI Express I/O Limit Register (IO_Limit_Register)                                                | 802         |
|      | 14.9.7   | PCI Express Secondary Status Register (Secondary_Status_Register)                                 | 803         |
|      | 14.9.8   | PCI Express Memory Base Register (Memory_Base_Register)                                           | 804         |
|      | 14.9.9   | PCI Express Memory Limit Register (Memory_Limit_Register)                                         | 804         |
|      | 14.9.10  | PCI Express Prefetchable Memory Base Register (Prefetchable_Memory_Base_Register)                 | 805         |
|      | 14.9.11  | PCI Express Prefetchable Memory Limit Register (Prefetchable_Memory_Limit_Register)               | 805         |
|      | 14.9.12  | PCI Express Prefetchable Base Upper 32 Bits Register (Prefetchable_Base_Upper_32_Bits_Regis       | ter)806     |
|      | 14.9.13  | PCI Express Prefetchable Limit Upper 32 Bits Register (Prefetchable_Limit_Upper_32_Bits_Register) | ister). 806 |
|      | 14.9.14  | PCI Express I/O Base Upper 16 Bits Register (IO_Base_Upper_16_Bits_Register)                      | 807         |
|      | 14.9.15  | PCI Express I/O Limit Upper 16 Bits Register (IO_Limit_Upper_16_Bits_Register)                    | 807         |
|      | 14.9.16  | Capabilities Pointer Register (Capabilities_Pointer_Register)                                     | 808         |
|      | 14.9.17  | PCI Express Interrupt Line Register (Interrupt_Line_Register)                                     | 808         |
|      |          |                                                                                                   |             |

| Section number Title |          | nber Title                                                                                                     | Page   |  |
|----------------------|----------|----------------------------------------------------------------------------------------------------------------|--------|--|
|                      | 14.9.18  | PCI Express Interrupt Pin Register (Interrupt_Pin_Register)                                                    | 809    |  |
|                      | 14.9.19  | PCI Express Bridge Control Register (Bridge_Control_Register)                                                  | 809    |  |
| 14.10                | PCI comp | patible device-specific configuration space                                                                    | 810    |  |
|                      | 14.10.1  | PCI Express Power Management Capability ID Register (Power_Management_Capability_ID_Register)                  | 812    |  |
|                      | 14.10.2  | PCI Express Power Management Capabilities Register (Power_Management_Capabilities_Register)                    | er)812 |  |
|                      | 14.10.3  | PCI Express Power Management Status and Control Register  (Power_Management_Status_and_Control_Register)       | 813    |  |
|                      | 14.10.4  | PCI Express Power Management Data Register (Power_Management_Data_Register)                                    | 814    |  |
|                      | 14.10.5  | PCI Express Capability ID Register (Capability_ID_Register)                                                    | 814    |  |
|                      | 14.10.6  | PCI Express Capabilities Register (Capabilities_Register)                                                      | 815    |  |
|                      | 14.10.7  | PCI Express Device Capabilities Register (Device_Capabilities_Register)                                        | 816    |  |
|                      | 14.10.8  | PCI Express Device Control Register (Device_Control_Register)                                                  | 817    |  |
|                      | 14.10.9  | PCI Express Device Status Register (Device_Status_Register)                                                    | 818    |  |
|                      | 14.10.10 | PCI Express Link Capabilities Register (Link_Capabilities_Register)                                            | 819    |  |
|                      | 14.10.11 | PCI Express Link Control Register (Link_Control_Register)                                                      | 820    |  |
|                      | 14.10.12 | PCI Express Link Status Register (Link_Status_Register)                                                        | 821    |  |
|                      | 14.10.13 | PCI Express Slot Capabilities Register (Slot_Capabilities_Register)                                            | 822    |  |
|                      | 14.10.14 | PCI Express Slot Control Register (Slot_Control_Register)                                                      | 823    |  |
|                      | 14.10.15 | PCI Express Slot Status Register (Slot_Status_Register)                                                        | 825    |  |
|                      | 14.10.16 | PCI Express Root Control Register (Root_Control_Register)                                                      | 826    |  |
|                      | 14.10.17 | PCI Express Root Status Register (Root_Status_Register)                                                        | 827    |  |
|                      | 14.10.18 | PCI Express MSI Message Capability ID Register (MSI_Message_Capability_ID_Register)                            | 828    |  |
|                      | 14.10.19 | PCI Express MSI Message Control Register (MSI_Message_Control_Register)                                        | 828    |  |
|                      | 14.10.20 | PCI Express MSI Message Address Register (MSI_Message_Address_Register)                                        | 829    |  |
|                      | 14.10.21 | PCI Express MSI Message Upper Address Register (MSI_Message_Upper_Address_Register)                            | 829    |  |
|                      | 14.10.22 | PCI Express MSI Message Data Register (MSI_Message_Data_Register)                                              | 830    |  |
| 14.11                | PCI Expr | ess extended configuration space                                                                               | 830    |  |
|                      | 14.11.1  | PCI Express Advanced Error Reporting Capability ID Register  (Advanced_Error_Reporting_Capability_ID_Register) | 832    |  |

| Section nu    | Section number  |                  | Title                                                                |     |  |
|---------------|-----------------|------------------|----------------------------------------------------------------------|-----|--|
| 14.11.2       | PCI Expre       | ss Uncorrectab   | le Error Status Register (Uncorrectable_Error_Status_Register)       | 832 |  |
| 14.11.3       | PCI Expre       | ss Uncorrectab   | le Error Mask Register (Uncorrectable_Error_Mask_Register)           | 834 |  |
| 14.11.4       | PCI Expre       | ss Uncorrectab   | le Error Severity Register (Uncorrectable_Error_Severity_Register)   | 835 |  |
| 14.11.5       | PCI Expre       | ss Correctable   | Error Status Register (Correctable_Error_Status_Register)            | 836 |  |
| 14.11.6       | PCI Expre       | ss Correctable   | Error Mask Register (Correctable_Error_Mask_Register)                | 837 |  |
| 14.11.7       | •               |                  | rror Capabilities and Control Register ilities_and_Control_Register) | 839 |  |
| 14.11.8       | PCI Expre       | ss Header Log    | Register 1 (Header_Log_Register_DWORD1)                              | 840 |  |
| 14.11.9       | PCI Expre       | ss Header Log    | Register 2 (Header_Log_Register_DWORD2)                              | 840 |  |
| 14.11.1       | 0 PCI Expre     | ss Header Log    | Register 3 (Header_Log_Register_DWORD3)                              | 841 |  |
| 14.11.1       | 1 PCI Expre     | ss Header Log    | Register 4 (Header_Log_Register_DWORD4)                              | 842 |  |
| 14.11.1       | 2 PCI Expre     | ss Root Error C  | Command Register (Root_Error_Command_Register)                       | 843 |  |
| 14.11.1       | 3 PCI Expre     | ess Root Error S | Status Register (Root_Error_Status_Register)                         | 844 |  |
| 14.11.1       | 4 PCI Expre     | ss Correctable   | Error Source ID Register (Correctable_Error_Source_ID_Register)      | 845 |  |
| 14.11.1       | 5 PCI Expre     | ss Error Source  | e ID Register (Error_Source_ID_Register)                             | 845 |  |
| 14.11.1       | 6 LTSSM S       | tate Status Regi | ister (LTSSM_State_Status_Register)                                  | 846 |  |
| 14.11.1       | 7 PCI Expre     | ss Controller C  | fore Clock Ratio Register (Controller_Core_Clock_Ratio_Register)     | 847 |  |
| 14.11.1       | 8 PCI Expre     | ss Power Mana    | ngement Timer Register (Power_Management_Timer_Register)             | 848 |  |
| 14.11.1       | 9 PCI Expre     | ess PME Time-0   | Out Register (PME_Time_Out_Register)                                 | 849 |  |
| 14.11.2       | 0 PCI Expre     | ss Subsystem V   | Vendor ID Update Register (Subsystem_Vendor_ID_Update_Register)      | 849 |  |
| 14.11.2       | 1 Configura     | tion Ready Reg   | gister (Configuration_Ready_Register)                                | 850 |  |
| 14.11.2       | 2 Flow Cont     | trol Update Tin  | neout Register (Flow_Control_Update_Timeout_Register)                | 851 |  |
| 14.11.2       | 3 Secondary     | Status Interrup  | ot Mask Register (Secondary_Status_Interrupt_Mask_Register)          | 852 |  |
| 14.12 Functio | nal description | on               |                                                                      | 853 |  |
| 14.12.1       | Architectu      | re               |                                                                      | 854 |  |
|               | 14.12.1.1       | PCI Express      | transactions                                                         | 854 |  |
|               | 14.12.1.2       | Byte ordering    | g                                                                    | 855 |  |
|               |                 | 14.12.1.2.1      | Address invariance                                                   | 856 |  |
|               |                 | 14.12.1.2.2      | Byte order for configuration transactions.                           | 857 |  |
|               |                 |                  |                                                                      |     |  |

| Section number |            | Title                                                              |     |  |
|----------------|------------|--------------------------------------------------------------------|-----|--|
|                | 14.12.1.3  | Lane reversal.                                                     | 858 |  |
|                | 14.12.1.4  | Transaction ordering rules                                         | 859 |  |
|                | 14.12.1.5  | PCI Express outbound ATMUs                                         | 860 |  |
|                | 14.12.1.6  | PCI Express inbound ATMUs                                          | 861 |  |
|                |            | 14.12.1.6.1 EP inbound ATMU implementation.                        | 861 |  |
|                |            | 14.12.1.6.2 RC inbound ATMU implementation                         | 862 |  |
|                | 14.12.1.7  | Memory space addressing                                            | 862 |  |
|                | 14.12.1.8  | I/O space addressing                                               | 863 |  |
|                | 14.12.1.9  | Configuration space addressing.                                    | 863 |  |
|                | 14.12.1.10 | PCI Express configuration space access.                            | 864 |  |
|                |            | 14.12.1.10.1 RC configuration register access                      | 864 |  |
|                |            | 14.12.1.10.1.1 PCI Express configuration access register mechanism | 865 |  |
|                |            | 14.12.1.10.1.2 Outbound ATMU configuration mechanism (RC-only)     | 865 |  |
|                |            | 14.12.1.10.2 EP configuration register access                      | 866 |  |
|                | 14.12.1.11 | Serialization of configuration and I/O writes.                     | 866 |  |
|                | 14.12.1.12 | Messages                                                           | 867 |  |
|                |            | 14.12.1.12.1 Outbound ATMU message generation                      | 867 |  |
|                |            | 14.12.1.12.2 Inbound messages                                      | 868 |  |
|                | 14.12.1.13 | Error handling.                                                    | 870 |  |
|                |            | 14.12.1.13.1 PCI Express error logging and signaling.              | 871 |  |
|                |            | 14.12.1.13.2 PCI Express controller internal interrupt sources     | 872 |  |
|                |            | 14.12.1.13.3 Error conditions                                      | 873 |  |
|                |            | 14.12.1.13.4 Error capture registers                               | 876 |  |
|                |            | 14.12.1.13.4.1 Error capture registers (outbound error)            | 876 |  |
|                |            | 14.12.1.13.4.2 Error capture registers (inbound error)             | 877 |  |
| 14.12.2        | Interrupts |                                                                    | 880 |  |
|                | 14.12.2.1  | EP interrupt generation.                                           | 880 |  |
|                |            | 14.12.2.1.1 Hardware INTx message generation                       | 880 |  |
|                |            | 14.12.2.1.2 Hardware MSI generation                                | 881 |  |
|                |            |                                                                    |     |  |

| Section number |            |                                                       |                 | Page                                |     |  |
|----------------|------------|-------------------------------------------------------|-----------------|-------------------------------------|-----|--|
|                |            |                                                       | 14.12.2.1.3     | Software INTx message generation    | 881 |  |
|                |            |                                                       | 14.12.2.1.4     | Software MSI generation             | 881 |  |
|                |            | 14.12.2.2                                             | RC handling     | of INTx message and MSI interrupts  | 882 |  |
|                |            |                                                       | 14.12.2.2.1     | INTx message handling               | 882 |  |
|                |            |                                                       | 14.12.2.2.2     | MSI handling                        | 882 |  |
|                | 14.12.3    | Initial cred                                          | it advertisemen | nt                                  | 882 |  |
|                | 14.12.4    | Power man                                             | agement         |                                     | 883 |  |
|                |            | 14.12.4.1                                             | L2/L3 ready     | link state                          | 884 |  |
|                | 14.12.5    | Hot reset                                             |                 |                                     | 884 |  |
|                | 14.12.6    | Link down                                             |                 |                                     | 884 |  |
| 14.13          | Initializa | 885                                                   |                 |                                     |     |  |
|                | 14.13.1    | 1 EP Boot mode and inbound configuration transactions |                 |                                     |     |  |
|                | 14.13.2    | Automatic                                             | link retraining | during initialization.              | 886 |  |
|                | 14.13.3    | Configurati                                           | ion accesses ar | nd inbound writes to CCSR space     | 886 |  |
|                |            |                                                       | Enhance         | Chapter 15                          |     |  |
| 15.1           | Overvier   | *7                                                    |                 | ed Three-Speed Ethernet Controllers | 880 |  |
| 15.1           |            |                                                       |                 |                                     |     |  |
| 15.3           |            |                                                       |                 |                                     |     |  |
|                |            | •                                                     |                 |                                     |     |  |
| 13.4           | 15.4.1     | 897                                                   |                 |                                     |     |  |
| 15.5           |            | 901                                                   |                 |                                     |     |  |
| 15.5           | 15.5.1     |                                                       |                 | y map                               |     |  |
|                | 15.5.2     | -                                                     |                 | eTSECx_TSEC_ID)                     |     |  |
|                | 15.5.3     |                                                       |                 | eTSECx_TSEC_ID2)                    |     |  |
|                | 15.5.4     |                                                       |                 | rister (eTSECx_IEVENTGn)            |     |  |
|                | 15.5.5     | -                                                     | -               | rister (eTSECx_IMASKGn)             |     |  |
|                | 15.5.6     | -                                                     |                 | TSEC <i>x</i> _EDIS)                |     |  |
|                | 15.5.7     |                                                       | _               | rister (eTSECx_EMAPG)               |     |  |
|                | 15.5.7     | Group Life                                            | n mapping reg   | (010D0A_DITELL O)                   | 743 |  |

| Section nu | mber Title                                                       | Page |
|------------|------------------------------------------------------------------|------|
| 15.5.8     | Ethernet control register (eTSECx_ECNTRL)                        | 945  |
| 15.5.9     | Pause time value register (eTSECx_PTV)                           | 949  |
| 15.5.10    | DMA control register (eTSECx_DMACTRL)                            | 950  |
| 15.5.11    | TBI PHY address register (eTSECx_TBIPA)                          | 952  |
| 15.5.12    | Transmit control register (eTSECx_TCTRL)                         | 952  |
| 15.5.13    | Transmit status register (eTSECx_TSTATn)                         | 956  |
| 15.5.14    | Default VLAN control word * (eTSECx_DFVLAN)                      | 960  |
| 15.5.15    | Transmit interrupt coalescing register (eTSECx_TXIC)             | 961  |
| 15.5.16    | Transmit queue control register * (eTSECx_TQUEUE)                | 962  |
| 15.5.17    | TxBD Rings 0-3 round-robin weightings * (eTSECx_TR03WT)          | 963  |
| 15.5.18    | TxBD Rings 4-7 round-robin weightings * (eTSECx_TR47WT)          | 964  |
| 15.5.19    | Tx data buffer pointer high bits * (eTSECx_TBDBPH)               | 965  |
| 15.5.20    | TxBD pointer for ring n (eTSECx_TBPTRn)                          | 966  |
| 15.5.21    | TxBD base address high bits * (eTSECx_TBASEH)                    | 966  |
| 15.5.22    | TxBD base address of ring n (eTSECx_TBASEn)                      | 967  |
| 15.5.23    | Tx time stamp identification tag [set n] * (eTSECx_TMR_TXTSn_ID) | 967  |
| 15.5.24    | Tx time stamp high [set n] * (eTSECx_TMR_TXTSn_H)                | 968  |
| 15.5.25    | Tx time stamp low [set n] * (eTSECx_TMR_TXTSn_L)                 | 968  |
| 15.5.26    | Receive control register (eTSECx_RCTRL)                          | 969  |
| 15.5.27    | Receive status register (eTSECx_RSTATn)                          | 972  |
| 15.5.28    | Receive interrupt coalescing register (eTSECx_RXIC)              | 975  |
| 15.5.29    | Receive queue control register * (eTSECx_RQUEUE)                 | 976  |
| 15.5.30    | Ring mapping register n * (eTSECx_RIRn)                          | 978  |
| 15.5.31    | Receive bit field extract control register * (eTSECx_RBIFX)      | 979  |
| 15.5.32    | Receive queue filing table address register * (eTSECx_RQFAR)     | 981  |
| 15.5.33    | Receive queue filer table control register * (eTSECx_RQFCR)      | 982  |
| 15.5.34    | Receive queue filing table property register * (eTSECx_RQFPR)    | 984  |
| 15.5.35    | Maximum receive buffer length register (eTSECx_MRBLR)            | 988  |
| 15.5.36    | Receive packet wakeup timer register (eTSECx_RPWT)               | 989  |
|            |                                                                  |      |

| Section num | nber Title                                                                   | Page |
|-------------|------------------------------------------------------------------------------|------|
| 15.5.37     | Rx data buffer pointer high bits * (eTSECx_RBDBPH)                           | 990  |
| 15.5.38     | RxBD pointer for ring n (eTSECx_RBPTRn)                                      | 990  |
| 15.5.39     | RxBD base address high bits * (eTSECx_RBASEH)                                | 991  |
| 15.5.40     | RxBD base address of ring n (eTSECx_RBASEn)                                  | 992  |
| 15.5.41     | Rx timer time stamp register high * (eTSECx_TMR_RXTS_H)                      | 992  |
| 15.5.42     | Rx timer time stamp register low * (eTSECx_TMR_RXTS_L)                       | 993  |
| 15.5.43     | MAC configuration register 1 (eTSECx_MACCFG1)                                | 994  |
| 15.5.44     | MAC configuration register 2 (eTSECx_MACCFG2)                                | 996  |
| 15.5.45     | Interpacket/interframe gap register (eTSECx_IPGIFG)                          | 998  |
| 15.5.46     | Half-duplex control (eTSECx_HAFDUP)                                          | 1000 |
| 15.5.47     | Maximum frame length (eTSECx_MAXFRM)                                         | 1001 |
| 15.5.48     | Interface status (eTSECx_IFSTAT)                                             | 1001 |
| 15.5.49     | MAC station address register 1 (eTSECx_MACSTNADDR1)                          | 1003 |
| 15.5.50     | MAC station address register 2 (eTSECx_MACSTNADDR2)                          | 1003 |
| 15.5.51     | MAC exact match address n, part 1 * (eTSECx_MACnADDR1)                       | 1004 |
| 15.5.52     | MAC exact match address n, part 2 * (eTSECx_MACnADDR2)                       | 1005 |
| 15.5.53     | Transmit and receive 64-byte frame counter (eTSECx_TR64)                     | 1006 |
| 15.5.54     | Transmit and receive 65- to 127-byte frame counter (eTSECx_TR127)            | 1006 |
| 15.5.55     | Transmit and receive 128- to 255-byte frame counter (eTSECx_TR255)           | 1007 |
| 15.5.56     | Transmit and receive 256- to 511-byte frame counter (eTSECx_TR511)           | 1007 |
| 15.5.57     | Transmit and receive 512- to 1023-byte frame counter (eTSECx_TR1K)           | 1008 |
| 15.5.58     | Transmit and receive 1024- to 1518-byte frame counter (eTSECx_TRMAX)         | 1008 |
| 15.5.59     | Transmit and receive 1519- to 1522-byte good VLAN frame count (eTSECx_TRMGV) | 1009 |
| 15.5.60     | Receive byte counter (eTSECx_RBYT)                                           | 1009 |
| 15.5.61     | Receive packet counter (eTSECx_RPKT)                                         | 1010 |
| 15.5.62     | Receive FCS error counter (eTSECx_RFCS)                                      | 1010 |
| 15.5.63     | Receive multicast packet counter (eTSECx_RMCA)                               | 1011 |
| 15.5.64     | Receive broadcast packet counter (eTSECx_RBCA)                               | 1011 |
| 15.5.65     | Receive control frame packet counter (eTSECx_RXCF)                           | 1012 |
|             |                                                                              |      |

| Section nun | nber Title                                                | Page |
|-------------|-----------------------------------------------------------|------|
| 15.5.66     | Receive PAUSE frame packet counter (eTSECx_RXPF)          | 1012 |
| 15.5.67     | Receive unknown OP code counter (eTSECx_RXUO)             | 1013 |
| 15.5.68     | Receive alignment error counter (eTSECx_RALN)             | 1013 |
| 15.5.69     | Receive frame length error counter (eTSECx_RFLR)          | 1014 |
| 15.5.70     | Receive code error counter (eTSECx_RCDE)                  | 1014 |
| 15.5.71     | Receive carrier sense error counter (eTSECx_RCSE)         | 1015 |
| 15.5.72     | Receive undersize packet counter (eTSECx_RUND)            | 1015 |
| 15.5.73     | Receive oversize packet counter (eTSECx_ROVR)             | 1016 |
| 15.5.74     | Receive fragments counter (eTSECx_RFRG)                   | 1016 |
| 15.5.75     | Receive jabber counter (eTSECx_RJBR)                      | 1017 |
| 15.5.76     | Receive drop counter (eTSECx_RDRP)                        | 1017 |
| 15.5.77     | Transmit byte counter (eTSECx_TBYT)                       | 1018 |
| 15.5.78     | Transmit packet counter (eTSECx_TPKT)                     | 1018 |
| 15.5.79     | Transmit multicast packet counter (eTSECx_TMCA)           | 1019 |
| 15.5.80     | Transmit broadcast packet counter (eTSECx_TBCA)           | 1019 |
| 15.5.81     | Transmit PAUSE control frame counter (eTSECx_TXPF)        | 1020 |
| 15.5.82     | Transmit deferral packet counter (eTSECx_TDFR)            | 1020 |
| 15.5.83     | Transmit excessive deferral packet counter (eTSECx_TEDF)  | 1021 |
| 15.5.84     | Transmit single collision packet counter (eTSECx_TSCL)    | 1021 |
| 15.5.85     | Transmit multiple collision packet counter (eTSECx_TMCL)  | 1022 |
| 15.5.86     | Transmit late collision packet counter (eTSECx_TLCL)      | 1022 |
| 15.5.87     | Transmit excessive collision packet counter (eTSECx_TXCL) | 1023 |
| 15.5.88     | Transmit total collision counter (eTSECx_TNCL)            | 1023 |
| 15.5.89     | Transmit drop frame counter (eTSECx_TDRP)                 | 1024 |
| 15.5.90     | Transmit jabber frame counter (eTSECx_TJBR)               | 1024 |
| 15.5.91     | Transmit FCS error counter (eTSECx_TFCS)                  | 1025 |
| 15.5.92     | Transmit control frame counter (eTSECx_TXCF)              | 1025 |
| 15.5.93     | Transmit oversize frame counter (eTSECx_TOVR)             | 1026 |
| 15.5.94     | Transmit undersize frame counter (eTSECx_TUND)            | 1026 |
|             |                                                           |      |

| Sect | ion nun  | nber Title                                                             | Page |
|------|----------|------------------------------------------------------------------------|------|
|      | 15.5.95  | Transmit fragments frame counter (eTSECx_TFRG)                         | 1027 |
|      | 15.5.96  | Carry register one (eTSECx_CAR1)                                       | 1028 |
|      | 15.5.97  | Carry register two (eTSECx_CAR2)                                       | 1030 |
|      | 15.5.98  | Carry register one mask register (eTSECx_CAM1)                         | 1032 |
|      | 15.5.99  | Carry register two mask register (eTSECx_CAM2)                         | 1034 |
|      | 15.5.100 | Receive filer rejected packet counter * (eTSECx_RREJ)                  | 1035 |
|      | 15.5.101 | Individual/group address register n (eTSECx_IGADDRn)                   | 1036 |
|      | 15.5.102 | Group address register n (eTSECx_GADDRn)                               | 1037 |
|      | 15.5.103 | Attribute register (eTSECx_ATTR)                                       | 1037 |
|      | 15.5.104 | Attribute extract length and extract index register * (eTSECx_ATTRELI) | 1039 |
|      | 15.5.105 | Receive Queue Parameters register n * (eTSECx_RQPRMn)                  | 1040 |
|      | 15.5.106 | Last Free RxBD pointer for ring n * (eTSECx_RFBPTRn)                   | 1041 |
|      | 15.5.107 | Interrupt steering register group n (eTSECx_ISRGn)                     | 1041 |
|      | 15.5.108 | Ring n Rx interrupt coalescing (eTSECx_RXICn)                          | 1044 |
|      | 15.5.109 | Ring n Tx interrupt coalescing (eTSECx_TXICn)                          | 1046 |
| 15.6 | eTSEC II | EEE 1588 PTP memory map/register definition                            | 1047 |
|      | 15.6.1   | Timer control register * (eTSEC1x_TMR_CTRL)                            | 1048 |
|      | 15.6.2   | Time stamp event register * (eTSEC1x_TMR_TEVENT)                       | 1052 |
|      | 15.6.3   | Timer event mask register * (eTSEC1x_TMR_TEMASK)                       | 1053 |
|      | 15.6.4   | Time stamp event register * (eTSEC1x_TMR_PEVENT)                       | 1054 |
|      | 15.6.5   | Timer event mask register * (eTSEC1x_TMR_PEMASK)                       | 1055 |
|      | 15.6.6   | Time stamp status register * (eTSEC1x_TMR_STAT)                        | 1056 |
|      | 15.6.7   | Timer counter high register * (eTSEC1x_TMR_CNT_H)                      | 1057 |
|      | 15.6.8   | Timer counter low register * (eTSEC1x_TMR_CNT_L)                       | 1058 |
|      | 15.6.9   | Timer drift compensation addend register * (eTSEC1x_TMR_ADD)           | 1059 |
|      | 15.6.10  | Timer accumulator register * (eTSEC1x_TMR_ACC)                         | 1060 |
|      | 15.6.11  | Timer prescale * (eTSEC1x_TMR_PRSC)                                    | 1060 |
|      | 15.6.12  | Timer offset high * (eTSEC1x_TMROFF_H)                                 | 1061 |
|      | 15.6.13  | Timer offset low * (eTSEC1x_TMROFF_L)                                  | 1061 |
|      |          |                                                                        |      |

| Sect | ion nur | mber Title                                                                                                 | Page |
|------|---------|------------------------------------------------------------------------------------------------------------|------|
|      | 15.6.14 | Timer alarm n high register * (eTSEC1x_TMR_ALARMn_H)                                                       | 1062 |
|      | 15.6.15 | Timer alarm n low register * (eTSEC1x_TMR_ALARMn_L)                                                        | 1063 |
|      | 15.6.16 | Timer fixed period interval n * (eTSEC1x_TMR_FIPERn)                                                       | 1063 |
|      | 15.6.17 | Time stamp of general purpose external trigger * (eTSEC1x_TMR_ETTSn_H)                                     | 1065 |
|      | 15.6.18 | Time stamp of general purpose external trigger * (eTSEC1x_TMR_ETTSn_L)                                     | 1065 |
| 15.7 | MDIO m  | emory map/register definition.                                                                             | 1066 |
|      | 15.7.1  | MDIO Interrupt event register (eTSECx1_MDIO_IEVENTM)                                                       | 1067 |
|      | 15.7.2  | MDIO Interrupt mask register (eTSECx1_MDIO_IMASKM)                                                         | 1069 |
|      | 15.7.3  | MDIO Error mapping register (eTSECx1_MDIO_EMAPM)                                                           | 1070 |
|      | 15.7.4  | MII management configuration register (eTSECx1_MDIO_MIIMCFG)                                               | 1070 |
|      | 15.7.5  | MII management command register (eTSECx1_MDIO_MIIMCOM)                                                     | 1072 |
|      | 15.7.6  | MII management address register (eTSECx1_MDIO_MIIMADD)                                                     | 1073 |
|      | 15.7.7  | MII management control register (eTSECx1_MDIO_MIIMCON)                                                     | 1074 |
|      | 15.7.8  | MII management status register (eTSECx1_MDIO_MIIMSTAT)                                                     | 1074 |
|      | 15.7.9  | MII management indicator register (eTSECx1_MDIO_MIIMIND)                                                   | 1075 |
| 15.8 | TBI men | nory map/register definition                                                                               | 1075 |
|      | 15.8.1  | Control (TBI_MII_Register_Set_CR)                                                                          | 1077 |
|      | 15.8.2  | Status (TBI_MII_Register_Set_SR)                                                                           | 1078 |
|      | 15.8.3  | AN Advertisement Register for 1000Base-X auto-negotiation (TBI_MII_Register_Set_ANA)                       | 1079 |
|      | 15.8.4  | AN Advertisement Register for SGMII auto-negotiation (TBI_MII_Register_Set_ANA_SGMII)                      | 1081 |
|      | 15.8.5  | AN Link Partner Base Page Ability Register for 1000Base-X auto-negotiation (TBI_MII_Register_Set_ANLPBPA)  | 1082 |
|      | 15.8.6  | AN Link Partner Base Page Ability Register for SGMII auto-negotiation (TBI_MII_Register_Set_ANLPBPA_SGMII) | 1083 |
|      | 15.8.7  | AN expansion (TBI_MII_Register_Set_ANEX)                                                                   | 1084 |
|      | 15.8.8  | AN next page transmit (TBI_MII_Register_Set_ANNPT)                                                         | 1085 |
|      | 15.8.9  | AN link partner ability next page (TBI_MII_Register_Set_ANLPANP)                                           | 1086 |
|      | 15.8.10 | Extended status (TBI_MII_Register_Set_EXST)                                                                | 1087 |
|      | 15.8.11 | Jitter diagnostics (TBI_MII_Register_Set_JD)                                                               | 1088 |

| Section number |          | mber           | Title                                                   | Page |
|----------------|----------|----------------|---------------------------------------------------------|------|
|                | 15.8.12  | TBI contro     | ol (TBI_MII_Register_Set_TBICON)                        | 1089 |
| 15.9           | Function | al description | on                                                      | 1090 |
|                | 15.9.1   | Programm       | ning model considerations                               | 1090 |
|                |          | 15.9.1.1       | MAC functionality                                       | 1091 |
|                |          |                | 15.9.1.1.1 Configuring the MAC                          | 1091 |
|                |          |                | 15.9.1.1.2 Controlling CSMA/CD                          | 1092 |
|                |          |                | 15.9.1.1.3 Handling packet collisions                   | 1092 |
|                |          |                | 15.9.1.1.4 Controlling packet flow                      | 1093 |
|                |          |                | 15.9.1.1.5 Controlling PHY links                        | 1094 |
|                |          | 15.9.1.2       | MIB registers                                           | 1094 |
|                |          | 15.9.1.3       | Hash function registers                                 | 1095 |
|                |          | 15.9.1.4       | Lossless flow control configuration registers           | 1096 |
|                |          | 15.9.1.5       | Hardware assist for IEEE1588 compliant timestamping     | 1096 |
|                |          | 15.9.1.6       | Interrupt steering and coalescing registers             | 1096 |
|                |          | 15.9.1.7       | Ten-bit interface (TBI)                                 | 1097 |
|                | 15.9.2   | Connectin      | g to physical interfaces on Ethernet                    | 1097 |
|                |          | 15.9.2.1       | Media-independent interface (MII)                       | 1098 |
|                |          | 15.9.2.2       | Reduced media-independent interface (RMII)              | 1099 |
|                |          | 15.9.2.3       | Reduced gigabit media-independent interface (RGMII)     | 1099 |
|                |          | 15.9.2.4       | Serial gigabit media-independent interface (SGMII)      | 1100 |
|                |          | 15.9.2.5       | SGMII interface                                         | 1101 |
|                | 15.9.3   | Gigabit Et     | thernet controller channel operation                    | 1101 |
|                |          | 15.9.3.1       | Initialization sequence                                 | 1102 |
|                |          |                | 15.9.3.1.1 Hardware controlled initialization           | 1102 |
|                |          |                | 15.9.3.1.2 User initialization                          | 1102 |
|                |          | 15.9.3.2       | Soft reset and reconfiguring procedure                  | 1103 |
|                |          |                | 15.9.3.2.1 Timer soft reset and reconfiguring procedure | 1104 |
|                |          | 15.9.3.3       | Gigabit Ethernet frame transmission.                    | 1105 |
|                |          | 15.9.3.4       | Gigabit Ethernet frame reception                        | 1107 |
|                |          |                |                                                         |      |

| Section number |            | Title         |                                                     | Page |
|----------------|------------|---------------|-----------------------------------------------------|------|
|                | 15.9.3.5   | Ethernet pre  | eamble customization                                | 1109 |
|                |            | 15.9.3.5.1    | User-defined preamble transmission                  | 1109 |
|                |            | 15.9.3.5.2    | User-visible preamble reception                     | 1110 |
|                | 15.9.3.6   | RMON supp     | port                                                | 1111 |
|                | 15.9.3.7   | Frame recog   | gnition                                             | 1111 |
|                |            | 15.9.3.7.1    | Destination address recognition and frame filtering | 1111 |
|                |            | 15.9.3.7.2    | Hash table algorithm                                | 1113 |
|                | 15.9.3.8   | Magic Pack    | et mode                                             | 1115 |
|                | 15.9.3.9   | Flow contro   | 1                                                   | 1115 |
|                | 15.9.3.10  | Grouping of   | f rings                                             | 1116 |
|                | 15.9.3.11  | Interrupt has | ndling                                              | 1117 |
|                |            | 15.9.3.11.1   | Interrupt coalescing                                | 1118 |
|                |            | 15.9.3.11.2   | Interrupt coalescing by frame count threshold       | 1119 |
|                |            | 15.9.3.11.3   | Interrupt coalescing by timer threshold             | 1119 |
|                | 15.9.3.12  | Interframe g  | gap time                                            | 1120 |
|                | 15.9.3.13  | Internal and  | external loop back                                  | 1121 |
|                | 15.9.3.14  | Error-handl   | ing procedure                                       | 1121 |
| 15.9.4         | TCP/IP of  | 1124          |                                                     |      |
|                | 15.9.4.1   | Frame contr   | rol blocks                                          | 1125 |
|                | 15.9.4.2   | Transmit pa   | th off-load and Tx PTP packet parsing               | 1125 |
|                | 15.9.4.3   | Receive pat   | h offload                                           | 1127 |
| 15.9.5         | Quality of | service (QoS) | provision                                           | 1130 |
|                | 15.9.5.1   | Receive par   | ser                                                 | 1130 |
|                | 15.9.5.2   | Receive que   | eue filer                                           | 1132 |
|                |            | 15.9.5.2.1    | Filing rules                                        | 1132 |
|                |            | 15.9.5.2.2    | Comparing properties with bit masks                 | 1134 |
|                |            | 15.9.5.2.3    | Special-case rules                                  | 1135 |
|                |            | 15.9.5.2.4    | Filer hash engine                                   | 1135 |
|                |            | 15.9.5.2.5    | Ring index mapping logic                            | 1137 |
|                |            |               |                                                     |      |

| Section number |            |                 | Title                                         | Page |
|----------------|------------|-----------------|-----------------------------------------------|------|
|                |            | 15.9.5.2.6      | Hash function                                 | 1137 |
|                |            | 15.9.5.2.7      | Filer interrupt events                        | 1138 |
|                |            | 15.9.5.2.8      | Setting up the receive queue filer table      | 1139 |
|                |            | 15.9.5.2.9      | Filer example-802.1p priority filing          | 1139 |
|                |            | 15.9.5.2.10     | Filer example-IP diff-serv code points filing | 1140 |
|                |            | 15.9.5.2.11     | Filer example-TCP and UDP port filing         | 1141 |
|                |            | 15.9.5.2.12     | Filer example-hash on AND chain (2-tuple)     | 1142 |
|                |            | 15.9.5.2.13     | Filer example-hash on AND chain (3-tuple)     | 1142 |
|                |            | 15.9.5.2.14     | Filer example-hash on AND chain (5-tuple)     | 1143 |
|                |            | 15.9.5.2.15     | Filer example-hash on cluster rules           | 1144 |
|                |            | 15.9.5.2.16     | Filer example-hash on compound rule           | 1144 |
|                |            | 15.9.5.2.17     | Filer example-interrupt from deep sleep       | 1145 |
|                | 15.9.5.3   | Transmissio     | n scheduling                                  | 1147 |
|                |            | 15.9.5.3.1      | Priority-based queuing (PBQ)                  | 1148 |
|                |            | 15.9.5.3.2      | Modified weighted round-robin queuing (MWRR)  | 1148 |
| 15.9.6         | Lossless f | low control     |                                               | 1150 |
|                | 15.9.6.1   | Back pressur    | re determination through free buffers         | 1150 |
|                | 15.9.6.2   | Software use    | e of hardware-initiated back pressure         | 1153 |
|                |            | 15.9.6.2.1      | Initialization                                | 1153 |
|                |            | 15.9.6.2.2      | Operation                                     | 1153 |
| 15.9.7         | Hardware   | assist for IEEE | E Std. 1588 compliant timestamping            | 1154 |
|                | 15.9.7.1   | Features        |                                               | 1154 |
|                | 15.9.7.2   | Timer logic     | overview                                      | 1155 |
|                | 15.9.7.3   | Time stamp      | insertion on the received packets             | 1157 |
|                |            | 15.9.7.3.1      | Time stamp point                              | 1157 |
|                | 15.9.7.4   | PTP packet      | parsing                                       | 1157 |
|                |            | 15.9.7.4.1      | General purpose filer rule                    | 1159 |
|                | 15.9.7.5   | Time stamp      | insertion on transmit packets                 | 1159 |
|                |            | 15.9.7.5.1      | Interrupts                                    | 1159 |

| Sect  | Section number |                                       |                 | Title                                              | Page |  |  |
|-------|----------------|---------------------------------------|-----------------|----------------------------------------------------|------|--|--|
|       |                |                                       | 15.9.7.5.2      | Error condition                                    | 1160 |  |  |
|       |                | 15.9.7.6                              | Tx PTP pack     | ket parsing                                        | 1161 |  |  |
|       | 15.9.8         | Buffer des                            | criptors        |                                                    | 1163 |  |  |
|       |                | 15.9.8.1                              | Data buffer     | descriptors                                        | 1163 |  |  |
|       |                | 15.9.8.2                              | Transmit dat    | ta buffer descriptors (TxBD)                       | 1165 |  |  |
|       |                | 15.9.8.3                              | Receive buff    | fer descriptors (RxBD)                             | 1168 |  |  |
| 15.10 | Initializa     | tion/applicat                         | tion informatio | 011                                                | 1170 |  |  |
|       | 15.10.1        | Interface n                           | node configura  | ation                                              | 1171 |  |  |
|       |                | 15.10.1.1                             | MII interface   | e mode                                             | 1171 |  |  |
|       |                | 15.10.1.2                             | RMII interfa    | ace mode                                           | 1174 |  |  |
|       |                | 15.10.1.3                             | RGMII inter     | face mode                                          | 1179 |  |  |
|       |                | 15.10.1.4                             | SGMII inter     | face support                                       | 1183 |  |  |
|       | 15.10.2        | Multigroup                            | p mode initiali | zation                                             | 1187 |  |  |
|       |                |                                       | Enhanced        | Chapter 16<br>secure digital host controller (eSDI | HC)  |  |  |
| 16.1  | eSDHC o        | overview                              |                 |                                                    | 1189 |  |  |
| 16.2  | eSDHC f        | features sum                          | mary            |                                                    | 1191 |  |  |
|       | 16.2.1         | Data transf                           | fer modes       |                                                    | 1192 |  |  |
| 16.3  | eSDHC e        | external sign                         | al description. |                                                    | 1192 |  |  |
| 16.4  | Enhance        | d Secure Dig                          | gital Host Cont | troller (eSDHC) Memory Map                         | 1193 |  |  |
|       | 16.4.1         | DMA syste                             | em address (eS  | SDHC_DSADDR)                                       | 1195 |  |  |
|       | 16.4.2         | Block attributes (eSDHC_BLKATTR)      |                 |                                                    |      |  |  |
|       | 16.4.3         | Command argument (eSDHC_CMDARG)       |                 |                                                    |      |  |  |
|       | 16.4.4         | Command transfer type (eSDHC_XFERTYP) |                 |                                                    |      |  |  |
|       | 16.4.5         | Command                               | response n (es  | SDHC_CMDRSPn)                                      | 1200 |  |  |
|       | 16.4.6         | Data buffe                            | r access port ( | eSDHC_DATPORT)                                     | 1201 |  |  |
|       | 16.4.7         | Present sta                           | te (eSDHC_Pl    | RSSTAT)                                            | 1202 |  |  |
|       | 16.4.8         | Protocol co                           | ontrol (eSDHC   | C_PROCTL)                                          | 1207 |  |  |
|       | 16.4.9         | System con                            | ntrol (eSDHC_   | _SYSCTL)                                           | 1210 |  |  |

| Sec  | tion nui | mber        | Title                                  | Page |
|------|----------|-------------|----------------------------------------|------|
|      | 16.4.10  | Interrupt s | status (eSDHC_IRQSTAT)                 | 1213 |
|      | 16.4.11  | Interrupt s | status enable (eSDHC_IRQSTATEN)        | 1217 |
|      | 16.4.12  | Interrupt s | signal enable (eSDHC_IRQSIGEN)         | 1220 |
|      | 16.4.13  | Auto CM     | D12 status (eSDHC_AUTOC12ERR)          | 1222 |
|      | 16.4.14  | Host contr  | roller capabilities (eSDHC_HOSTCAPBLT) | 1226 |
|      | 16.4.15  | Watermar    | rk level (eSDHC_WML)                   | 1228 |
|      | 16.4.16  | Force eve   | nt (eSDHC_FEVT)                        | 1229 |
|      | 16.4.17  | Host contr  | roller version (eSDHC_HOSTVER)         | 1231 |
|      | 16.4.18  | DMA con     | ntrol register (eSDHC_DCR)             | 1232 |
| 16.5 | eSDHC    | 1233        |                                        |      |
|      | 16.5.1   | Data buffe  | er                                     | 1233 |
|      |          | 16.5.1.1    | Write operation sequence               | 1234 |
|      |          | 16.5.1.2    | Read operation sequence                | 1235 |
|      |          | 16.5.1.3    | Data buffer size                       | 1235 |
|      | 16.5.2   | DMA CC      | B interface                            | 1236 |
|      |          | 16.5.2.1    | Internal DMA request                   | 1236 |
|      |          | 16.5.2.2    | DMA burst length                       | 1237 |
|      |          | 16.5.2.3    | CCB Master interface                   | 1237 |
|      | 16.5.3   | SD protoc   | col unit                               | 1238 |
|      |          | 16.5.3.1    | SD transceiver                         | 1238 |
|      |          | 16.5.3.2    | SD clock and monitor                   | 1238 |
|      |          | 16.5.3.3    | Command agent                          | 1239 |
|      |          | 16.5.3.4    | Data agent                             | 1239 |
|      | 16.5.4   | Clock and   | l reset manager                        | 1240 |
|      | 16.5.5   | Clock gen   | nerator                                | 1240 |
|      | 16.5.6   | Card inser  | rtion and removal detection            | 1240 |
|      | 16.5.7   | Power ma    | anagement and wake-up events           | 1241 |
|      |          | 16.5.7.1    | Setting wake-up events                 | 1241 |

| Sec | tion nu    | mber          | Title                                         | Page |  |
|-----|------------|---------------|-----------------------------------------------|------|--|
| 6.6 | Initializa | ation/applica | ation/application information                 |      |  |
|     | 16.6.1     | Command       | I send and response receive basic operation   | 1242 |  |
|     | 16.6.2     | Card ident    | tification mode                               | 1243 |  |
|     |            | 16.6.2.1      | Card detect                                   | 1243 |  |
|     |            | 16.6.2.2      | Reset                                         | 1244 |  |
|     |            | 16.6.2.3      | Voltage validation.                           | 1245 |  |
|     |            | 16.6.2.4      | Card registry                                 | 1246 |  |
|     | 16.6.3     | Card acce     | ss                                            | 1248 |  |
|     |            | 16.6.3.1      | Block write                                   | 1248 |  |
|     |            |               | 16.6.3.1.1 Normal write                       | 1248 |  |
|     |            |               | 16.6.3.1.2 Write with pause                   | 1249 |  |
|     |            | 16.6.3.2      | Block read                                    | 1250 |  |
|     |            |               | 16.6.3.2.1 Normal read                        | 1250 |  |
|     |            |               | 16.6.3.2.2 Read with pause                    | 1251 |  |
|     |            | 16.6.3.3      | Transfer error                                | 1252 |  |
|     |            |               | 16.6.3.3.1 CRC error                          | 1252 |  |
|     |            |               | 16.6.3.3.2 Internal DMA error                 | 1252 |  |
|     |            |               | 16.6.3.3.3 Auto CMD12 error                   | 1253 |  |
|     |            | 16.6.3.4      | Card interrupt                                | 1253 |  |
|     | 16.6.4     | Switch fur    | nction                                        | 1253 |  |
|     |            | 16.6.4.1      | Query, enable and disable SD high speed mode  | 1254 |  |
|     |            | 16.6.4.2      | Query, enable and disable MMC high speed mode | 1254 |  |
|     |            | 16.6.4.3      | Set MMC bus width                             | 1255 |  |
|     | 16.6.5     | Command       | ls for MMC/SD                                 | 1255 |  |
|     | 16.6.6     | Software 1    | restrictions                                  | 1261 |  |
|     |            |               | Chapter 17<br>Universal Serial Bus Interface  |      |  |
| 7.1 | Introduc   | ction         |                                               | 1263 |  |
|     | 17.1.1     | Overview      |                                               | 1264 |  |
|     |            |               |                                               |      |  |

| Sec  | tion nui | mber Title                                                          | Page |
|------|----------|---------------------------------------------------------------------|------|
|      | 17.1.2   | Features                                                            | 1264 |
|      | 17.1.3   | Modes of operation                                                  | 1265 |
| 17.2 | USB ext  | ernal signals                                                       | 1265 |
|      | 17.2.1   | ULPI interface.                                                     | 1265 |
|      | 17.2.2   | PHY clocks                                                          | 1266 |
| 17.3 | USB me   | mory map/register definition                                        | 1267 |
|      | 17.3.1   | Identification register (USB_ID)                                    | 1269 |
|      | 17.3.2   | Capability register length (USB_CAPLENGTH)                          | 1270 |
|      | 17.3.3   | Host controller interface version number (USB_HCIVERSION)           | 1271 |
|      | 17.3.4   | Host controller structural parameters (USB_HCSPARAMS)               | 1271 |
|      | 17.3.5   | Host controller capability parameters (USB_HCCPARAMS)               | 1273 |
|      | 17.3.6   | Device controller interface version number (USB_DCIVERSION)         | 1275 |
|      | 17.3.7   | Device controller capability parameters (USB_DCCPARAMS)             | 1276 |
|      | 17.3.8   | USB command (USB_USBCMD)                                            | 1276 |
|      | 17.3.9   | USB status (USB_USBSTS)                                             | 1281 |
|      | 17.3.10  | USB interrupt enable (USB_USBINTR)                                  | 1285 |
|      | 17.3.11  | USB frame index (USB_FRINDEX)                                       | 1287 |
|      | 17.3.12  | Periodic frame list base address [host mode] (USB_PERIODICLISTBASE) | 1288 |
|      | 17.3.13  | USB device address [device mode] (USB_DEVICEADDR)                   | 1289 |
|      | 17.3.14  | Next asynchronous list addr [host mode] (USB_ASYNCLISTADDR)         | 1289 |
|      | 17.3.15  | Address at endpoint list [device mode] (USB_ENDPOINTLISTADDR)       | 1290 |
|      | 17.3.16  | Master interface data burst size (USB_BURSTSIZE)                    | 1290 |
|      | 17.3.17  | Transmit FIFO tuning controls (USB_TXFILLTUNING)                    | 1291 |
|      | 17.3.18  | ULPI register access (USB_ULPI_VIEWPORT)                            | 1293 |
|      | 17.3.19  | Configured flag register (USB_CONFIGFLAG)                           | 1295 |
|      | 17.3.20  | Port status/control (USB_PORTSC)                                    | 1296 |
|      | 17.3.21  | USB device mode (USB_USBMODE)                                       | 1303 |
|      | 17.3.22  | Endpoint setup status (USB_ENDPTSETUPSTAT)                          | 1304 |
|      | 17.3.23  | Endpoint initialization (USB_ENDPOINTPRIME)                         | 1305 |
|      |          |                                                                     |      |

| Sec  | tion nur  | mber           | Title                                          | Page |
|------|-----------|----------------|------------------------------------------------|------|
|      | 17.3.24   | Endpoint t     | flush (USB_ENDPTFLUSH)                         | 1306 |
|      | 17.3.25   | Endpoint s     | status (USB_ENDPTSTATUS)                       | 1306 |
|      | 17.3.26   | Endpoint of    | complete (USB_ENDPTCOMPLETE)                   | 1307 |
|      | 17.3.27   | Endpoint of    | control 0 (USB_ENDPTCTRL0)                     | 1309 |
|      | 17.3.28   | Endpoint       | control n (USB_ENDPTCTRLn)                     | 1311 |
|      | 17.3.29   | Snoop n (      | USB_SNOOPn)                                    | 1313 |
|      | 17.3.30   | Age count      | t threshold (USB_AGE_CNT_THRESH)               | 1314 |
|      | 17.3.31   | Priority co    | ontrol (USB_PRI_CTRL)                          | 1316 |
|      | 17.3.32   | System int     | terface control (USB_SI_CTRL)                  | 1317 |
|      | 17.3.33   | Control (U     | JSB_CONTROL)                                   | 1318 |
| 17.4 | Function  | al description | 1319                                           |      |
|      | 17.4.1    | System in      | terface                                        | 1319 |
|      | 17.4.2    | DMA eng        | ine                                            | 1319 |
|      | 17.4.3    | FIFO RAM       | M controller                                   | 1320 |
|      | 17.4.4    | PHY inter      | face                                           | 1320 |
| 17.5 | Host data | a structures.  |                                                | 1320 |
|      | 17.5.1    | Periodic fi    | rame list                                      | 1321 |
|      | 17.5.2    | Asynchron      | nous list queue head pointer                   | 1323 |
|      | 17.5.3    | Isochrono      | us (high-speed) transfer descriptor (iTD)      | 1323 |
|      |           | 17.5.3.1       | Next link pointer-iTD                          | 1324 |
|      |           | 17.5.3.2       | iTD transaction status and control list        | 1325 |
|      |           | 17.5.3.3       | iTD buffer page pointer list (plus)            | 1326 |
|      | 17.5.4    | Split trans    | saction isochronous transfer descriptor (siTD) | 1328 |
|      |           | 17.5.4.1       | Next link pointer-siTD                         | 1328 |
|      |           | 17.5.4.2       | siTD endpoint capabilities/characteristics     | 1329 |
|      |           | 17.5.4.3       | siTD transfer state                            | 1330 |
|      |           | 17.5.4.4       | siTD buffer pointer list (plus)                | 1331 |
|      |           | 17.5.4.5       | siTD back link pointer                         | 1332 |
|      |           |                |                                                |      |

| Section number |         |                   | Title                                             | Page |  |
|----------------|---------|-------------------|---------------------------------------------------|------|--|
|                | 17.5.5  | Queue ele         | ement transfer descriptor (qTD)                   | 1332 |  |
|                |         | 17.5.5.1          | Next qTD pointer                                  | 1333 |  |
|                |         | 17.5.5.2          | Alternate next qTD pointer                        | 1334 |  |
|                |         | 17.5.5.3          | qTD token                                         | 1334 |  |
|                |         | 17.5.5.4          | qTD buffer page pointer list                      | 1337 |  |
|                | 17.5.6  | Queue hea         | ad                                                | 1338 |  |
|                |         | 17.5.6.1          | Queue head horizontal link pointer                | 1338 |  |
|                |         | 17.5.6.2          | Endpoint capabilities/characteristics             | 1339 |  |
|                |         | 17.5.6.3          | Transfer overlay                                  | 1341 |  |
|                | 17.5.7  | Periodic f        | rame span traversal node (FSTN)                   | 1342 |  |
|                |         | 17.5.7.1          | FSTN normal path pointer                          | 1343 |  |
|                |         | 17.5.7.2          | FSTN back path link pointer                       | 1344 |  |
| 17.6           | Host op | erations          |                                                   | 1344 |  |
|                | 17.6.1  | Host contr        | roller initialization                             | 1344 |  |
|                | 17.6.2  | Power por         | rt                                                | 1346 |  |
|                | 17.6.3  | Reporting         | over-current                                      | 1346 |  |
|                | 17.6.4  | Suspend/r         | resume                                            | 1346 |  |
|                |         | 17.6.4.1          | Port suspend/resume                               | 1347 |  |
|                | 17.6.5  | Schedule          | traversal rules                                   | 1349 |  |
|                | 17.6.6  | Periodic s        | chedule frame boundaries vs. bus frame boundaries | 1351 |  |
|                | 17.6.7  | Periodic schedule |                                                   |      |  |
|                | 17.6.8  | Managing          | g isochronous transfers using iTDs                | 1354 |  |
|                |         | 17.6.8.1          | Host controller operational model for iTDs        | 1355 |  |
|                |         | 17.6.8.2          | Software operational model for iTDs               | 1357 |  |
|                |         |                   | 17.6.8.2.1 Periodic scheduling threshold          | 1359 |  |
|                | 17.6.9  | Asynchro          | nous schedule                                     | 1360 |  |
|                |         | 17.6.9.1          | Adding queue heads to asynchronous schedule       | 1362 |  |
|                |         | 17.6.9.2          | Removing queue heads from asynchronous schedule   | 1362 |  |
|                |         | 17.6.9.3          | Empty asynchronous schedule detection             | 1365 |  |
|                |         |                   |                                                   |      |  |

| Section number |              |                 | Page                                                          |      |
|----------------|--------------|-----------------|---------------------------------------------------------------|------|
|                | 17.6.9.4     | Asynchronou     | us schedule traversal: Start event                            | 1366 |
|                | 17.6.9.5     | Reclamation     | status bit (USBSTS Register)                                  | 1366 |
| 17.6.10        | Managing     | control/bulk/in | terrupt transfers via queue heads                             | 1367 |
|                | 17.6.10.1    | Buffer pointe   | er list use for data streaming with qTDs                      | 1368 |
|                | 17.6.10.2    | Adding inter    | rupt queue heads to the periodic schedule                     | 1370 |
|                | 17.6.10.3    | Managing tra    | ansfer complete interrupts from queue heads                   | 1370 |
| 17.6.11        | Ping contro  | ol              |                                                               | 1371 |
| 17.6.12        | Split transa | actions         |                                                               | 1372 |
|                | 17.6.12.1    | Split transact  | tions for asynchronous transfers                              | 1373 |
|                |              | 17.6.12.1.1     | Asynchronous-do-start-split                                   | 1373 |
|                |              | 17.6.12.1.2     | Asynchronous-do-complete-split                                | 1374 |
|                | 17.6.12.2    | Split transact  | ion interrupt                                                 | 1375 |
|                |              | 17.6.12.2.1     | Split transaction scheduling mechanisms for interrupt         | 1376 |
|                |              | 17.6.12.2.2     | Host controller operational model for FSTNs                   | 1379 |
|                |              | 17.6.12.2.3     | Software operational model for FSTNs                          | 1382 |
|                |              | 17.6.12.2.4     | Tracking split transaction progress for interrupt transfers   | 1383 |
|                |              | 17.6.12.2.5     | Split transaction execution state machine for interrupt       | 1384 |
|                |              | 17.6.12.2.6     | Periodic interrupt-do-start-split                             | 1385 |
|                |              | 17.6.12.2.7     | Periodic interrupt-do-complete-split                          | 1386 |
|                |              | 17.6.12.2.8     | Managing the QH[FrameTag] field                               | 1390 |
|                |              | 17.6.12.2.9     | Rebalancing the periodic schedule                             | 1391 |
|                | 17.6.12.3    | Split transact  | tion isochronous                                              | 1392 |
|                |              | 17.6.12.3.1     | Split transaction scheduling mechanisms for isochronous       | 1392 |
|                |              | 17.6.12.3.2     | Tracking split transaction progress for isochronous transfers | 1397 |
|                |              | 17.6.12.3.3     | Split transaction execution state machine for isochronous     | 1399 |
|                |              | 17.6.12.3.4     | Periodic isochronous-do-start-split                           | 1400 |
|                |              | 17.6.12.3.5     | Periodic isochronous-do complete split                        | 1402 |
|                |              | 17.6.12.3.6     | Complete-split for scheduling boundary cases 2a, 2b           | 1405 |
|                |              | 17.6.12.3.7     | Split transaction for isochronous-processing example          | 1407 |
|                |              |                 |                                                               |      |

| Sec  | ection number |               | Title              |                                               | Page |
|------|---------------|---------------|--------------------|-----------------------------------------------|------|
|      | 17.6.13       | Port test m   | odes               |                                               | 1409 |
|      | 17.6.14       | Interrupts.   |                    |                                               | 1409 |
|      |               | 17.6.14.1     | Transfer/tran      | saction based interrupts                      | 1411 |
|      |               |               | 17.6.14.1.1        | Transaction error                             | 1411 |
|      |               |               | 17.6.14.1.2        | Serial bus babble                             | 1411 |
|      |               |               | 17.6.14.1.3        | Data buffer error                             | 1412 |
|      |               |               | 17.6.14.1.4        | USB interrupt (interrupt on completion (IOC)) | 1413 |
|      |               |               | 17.6.14.1.5        | Short packet                                  | 1413 |
|      |               | 17.6.14.2     | Host controll      | ler event interrupts                          | 1413 |
|      |               |               | 17.6.14.2.1        | Port change events                            | 1414 |
|      |               |               | 17.6.14.2.2        | Frame list rollover                           | 1414 |
|      |               |               | 17.6.14.2.3        | Interrupt on async advance                    | 1414 |
|      |               |               | 17.6.14.2.4        | Host system error                             | 1414 |
| 17.7 | Device d      | ata structure | S                  |                                               | 1415 |
|      | 17.7.1        | Endpoint of   | ueue head          |                                               | 1416 |
|      |               | 17.7.1.1      | Endpoint cap       | pabilities/characteristics                    | 1417 |
|      |               | 17.7.1.2      | Transfer over      | rlay                                          | 1418 |
|      |               | 17.7.1.3      | Current dTD        | pointer                                       | 1418 |
|      |               | 17.7.1.4      | Setup buffer.      |                                               | 1419 |
|      | 17.7.2        | Endpoint t    | ransfer descrip    | tor (dTD)                                     | 1419 |
| 17.8 | Device o      | perational m  | nodel              |                                               | 1421 |
|      | 17.8.1        | Device con    | ntroller initializ | zation                                        | 1422 |
|      | 17.8.2        | Port state a  | and control        |                                               | 1423 |
|      |               | 17.8.2.1      | Bus reset          |                                               | 1425 |
|      |               | 17.8.2.2      | Suspend/resu       | ıme                                           | 1426 |
|      |               |               | 17.8.2.2.1         | Suspend description                           | 1426 |
|      |               |               | 17.8.2.2.2         | Suspend operational model                     | 1427 |
|      |               |               | 17.8.2.2.3         | Resume                                        | 1427 |
|      |               |               |                    |                                               |      |

| Section nu | mber     |                | Title                                       | Page |
|------------|----------|----------------|---------------------------------------------|------|
| 17.8.3     | Managing | endpoints      |                                             | 1427 |
|            | 17.8.3.1 | Endpoint in    | itialization                                | 1428 |
|            |          | 17.8.3.1.1     | Stalling                                    | 1429 |
|            | 17.8.3.2 | Data toggle.   |                                             | 1429 |
|            |          | 17.8.3.2.1     | Data toggle reset                           | 1430 |
|            |          | 17.8.3.2.2     | Data toggle inhibit                         | 1430 |
|            | 17.8.3.3 | Device oper    | rational model for packet transfers         | 1430 |
|            |          | 17.8.3.3.1     | Priming transmit endpoints                  | 1431 |
|            |          | 17.8.3.3.2     | Priming receive endpoints                   | 1431 |
|            | 17.8.3.4 | Interrupt/bu   | lk endpoint operational model               | 1431 |
|            |          | 17.8.3.4.1     | Interrupt/bulk endpoint bus response matrix | 1433 |
|            | 17.8.3.5 | Control end    | point operation model                       | 1434 |
|            |          | 17.8.3.5.1     | Setup phase                                 | 1434 |
|            |          | 17.8.3.5.2     | Data phase                                  | 1435 |
|            |          | 17.8.3.5.3     | Status phase                                | 1435 |
|            |          | 17.8.3.5.4     | Control endpoint bus response matrix        | 1436 |
|            | 17.8.3.6 | Isochronous    | s endpoint operational model                | 1436 |
|            |          | 17.8.3.6.1     | Isochronous pipe synchronization            | 1438 |
|            |          | 17.8.3.6.2     | Isochronous endpoint bus response matrix    | 1438 |
| 17.8.4     | Managing | queue heads    |                                             | 1439 |
|            | 17.8.4.1 | Queue head     | initialization                              | 1440 |
|            | 17.8.4.2 | Operational    | model for setup transfers                   | 1440 |
| 17.8.5     | Managing | transfers with | transfer descriptors                        | 1441 |
|            | 17.8.5.1 | Software lin   | ık pointers                                 | 1441 |
|            | 17.8.5.2 | Building a tr  | ransfer descriptor                          | 1442 |
|            | 17.8.5.3 | Executing a    | transfer descriptor                         | 1442 |
|            | 17.8.5.4 | Transfer cor   | mpletion                                    | 1443 |
|            | 17.8.5.5 | Flushing/de    | priming an endpoint                         | 1444 |
|            | 17.8.5.6 | Device error   | r matrix                                    | 1445 |
|            |          |                |                                             |      |

| ction number |              | Title             |                                                           | Page |  |
|--------------|--------------|-------------------|-----------------------------------------------------------|------|--|
| 17.8.6       | Servicing    | interrupts        |                                                           | 1445 |  |
|              | 17.8.6.1     | High-freque       | ncy interrupts                                            | 1445 |  |
|              | 17.8.6.2     | Low-frequen       | ncy interrupts                                            | 1440 |  |
|              | 17.8.6.3     | Error interru     | pts                                                       | 1440 |  |
| Deviation    | ons from the | EHCI specifica    | ations                                                    | 1447 |  |
| 17.9.1       | Embedded     | l transaction tra | anslator function                                         | 1447 |  |
|              | 17.9.1.1     | Capability re     | egisters                                                  | 1447 |  |
|              | 17.9.1.2     | Operational       | registers                                                 | 1448 |  |
|              | 17.9.1.3     | Discovery         |                                                           | 1448 |  |
|              | 17.9.1.4     | Data structu      | res                                                       | 1449 |  |
|              | 17.9.1.5     | Operational       | model                                                     | 1450 |  |
|              |              | 17.9.1.5.1        | Microframe pipeline                                       | 1450 |  |
|              |              | 17.9.1.5.2        | Split state machines                                      | 1450 |  |
|              |              | 17.9.1.5.3        | Asynchronous transaction scheduling and buffer management | 145  |  |
|              |              | 17.9.1.5.4        | Periodic transaction scheduling and buffer management     | 145  |  |
|              |              | 17.9.1.5.5        | Multiple transaction translators                          | 1452 |  |
| 17.9.2       | Device op    | eration           |                                                           | 1452 |  |
| 17.9.3       | Non-zero     | fields the regis  | ter file                                                  | 1452 |  |
| 17.9.4       | SOF inter    | rupt              |                                                           | 1452 |  |
| 17.9.5       | Embedded     | l design          |                                                           | 1452 |  |
|              | 17.9.5.1     | Frame adjus       | t register                                                | 1453 |  |
| 17.9.6       | Miscellan    | eous variations   | from EHCI                                                 | 1453 |  |
|              | 17.9.6.1     | Discovery         |                                                           | 1453 |  |
|              |              | 17.9.6.1.1        | Port reset                                                | 1453 |  |
|              |              | 17.9.6.1.2        | Port speed detection                                      | 1454 |  |
|              |              | Enh               | Chapter 18 anced Serial Peripheral Interface              |      |  |
| Introduc     | tion         |                   | •                                                         | 1455 |  |
| 18.1.1       | Features     |                   |                                                           | 1450 |  |

| Sect | tion nu   | mber Title                                                  | Page |  |
|------|-----------|-------------------------------------------------------------|------|--|
|      | 18.1.2    | eSPI transmission and reception process                     | 1457 |  |
|      | 18.1.3    | Modes of operation                                          | 1457 |  |
| 18.2 | External  | signal descriptions                                         | 1458 |  |
|      | 18.2.1    | Overview                                                    | 1458 |  |
|      | 18.2.2    | ESPI detailed signal descriptions                           | 1459 |  |
| 18.3 | Enhance   | ed serial peripheral interface (eSPI) memory map            | 1460 |  |
|      | 18.3.1    | eSPI mode register (ESPI_SPMODE)                            | 1461 |  |
|      | 18.3.2    | eSPI event register (ESPI_SPIE)                             | 1463 |  |
|      | 18.3.3    | eSPI mask register (ESPI_SPIM)                              | 1465 |  |
|      | 18.3.4    | eSPI command register (ESPI_SPCOM)                          | 1467 |  |
|      | 18.3.5    | eSPI transmit FIFO access register (ESPI_SPITF)             | 1469 |  |
|      | 18.3.6    | eSPI receive FIFO access register (ESPI_SPIRF)              | 1471 |  |
|      | 18.3.7    | eSPI CS0 mode register (ESPI_SPMODE0)                       | 1472 |  |
|      | 18.3.8    | eSPI CS1 mode register (ESPI_SPMODE1)                       | 1474 |  |
|      | 18.3.9    | eSPI CS2 mode register (ESPI_SPMODE2)                       | 1476 |  |
|      | 18.3.10   | eSPI CS3 mode register (ESPI_SPMODE3)                       | 1478 |  |
| 18.4 | eSPI trai | nsfer formats                                               | 1479 |  |
| 18.5 | CI and C  | CP values for various eSPI devices                          | 1480 |  |
| 18.6 | eSPI pro  | ogramming examples                                          | 1481 |  |
|      | 18.6.1    | 24-bit address example                                      | 1481 |  |
|      | 18.6.2    | 16-bit address example                                      | 1481 |  |
|      |           | Chapter 19 Device Performance Monitor                       |      |  |
| 19.1 | Introduc  | tion                                                        | 1483 |  |
|      | 19.1.1    | Overview                                                    | 1484 |  |
|      | 19.1.2    | Features                                                    | 1485 |  |
| 19.2 | Signal d  | escriptions                                                 | 1486 |  |
| 19.3 | PERFM     | ON Memory Map/Register Definition                           | 1486 |  |
|      | 19.3.1    | Performance monitor global control register (PERFMON_PMGC0) | 1488 |  |

| Sec  | tion nu    | mber Title                                                     | Page |
|------|------------|----------------------------------------------------------------|------|
|      | 19.3.2     | Performance monitor local control register A0 (PERFMON_PMLCA0) | 1489 |
|      | 19.3.3     | Performance monitor local control register B0 (PERFMON_PMLCB0) | 1490 |
|      | 19.3.4     | Performance monitor counter 0 lower (PERFMON_PMC0_upper)       | 1491 |
|      | 19.3.5     | Performance monitor counter 0 upper (PERFMON_PMC0_lower)       | 1492 |
|      | 19.3.6     | Performance monitor local control register An (PERFMON_PMLCAn) | 1493 |
|      | 19.3.7     | Performance monitor local control register Bn (PERFMON_PMLCBn) | 1494 |
|      | 19.3.8     | Performance monitor counter n (PERFMON_PMCn)                   | 1495 |
| 19.4 | Function   | nal description                                                | 1496 |
|      | 19.4.1     | Performance monitor interrupt                                  | 1496 |
|      | 19.4.2     | Event counting                                                 | 1496 |
|      | 19.4.3     | Threshold events                                               | 1497 |
|      | 19.4.4     | Chaining                                                       | 1498 |
|      | 19.4.5     | Triggering                                                     | 1499 |
|      | 19.4.6     | Burstiness counting                                            | 1499 |
|      | 19.4.7     | Performance monitor events                                     | 1502 |
|      | 19.4.8     | Performance monitor examples                                   | 1511 |
| 19.5 | Initializa | ation/application information                                  | 1512 |
|      |            | Chapter 20<br>Global Utilities                                 |      |
| 20.1 | Introduc   | ction                                                          | 1515 |
| 20.2 | Overvie    | w                                                              | 1515 |
| 20.3 | Global u   | utilities features                                             | 1515 |
|      | 20.3.1     | Power management and block disables                            | 1515 |
|      | 20.3.2     | Accessing current POR configuration settings                   | 1516 |
|      | 20.3.3     | Clock control.                                                 | 1516 |
| 20.4 | Global u   | utilities external signal description                          | 1516 |
|      | 20.4.1     | Signals overview                                               | 1516 |
|      | 20.4.2     | Detailed signal descriptions                                   | 1516 |

| Sec  | ection number Title |                                                               | Page |
|------|---------------------|---------------------------------------------------------------|------|
| 20.5 | GUTS M              | Iemory Map/Register Definition                                | 1518 |
|      | 20.5.1              | POR PLL ratio status register (GUTS_PORPLLSR)                 | 1521 |
|      | 20.5.2              | POR boot mode status register (GUTS_PORBMSR)                  | 1524 |
|      | 20.5.3              | POR device status register (GUTS_PORDEVSR)                    | 1526 |
|      | 20.5.4              | POR debug mode status register (GUTS_PORDBGMSR)               | 1529 |
|      | 20.5.5              | POR device status register 2 (GUTS_PORDEVSR2)                 | 1531 |
|      | 20.5.6              | General-purpose POR configuration register (GUTS_GPPORCR)     | 1533 |
|      | 20.5.7              | Alternate function signal multiplex control (GUTS_PMUXCR)     | 1534 |
|      | 20.5.8              | Device disable register (GUTS_DEVDISR)                        | 1536 |
|      | 20.5.9              | Power management control and status register (GUTS_POWMGTCSR) | 1540 |
|      | 20.5.10             | Power management clock disable register (GUTS_PMCDR)          | 1543 |
|      | 20.5.11             | Machine check summary register (GUTS_MCPSUMR)                 | 1544 |
|      | 20.5.12             | Reset request status and control register (GUTS_RSTRSCR)      | 1547 |
|      | 20.5.13             | Exception reset control register (GUTS_ECTRSTCR)              | 1548 |
|      | 20.5.14             | Automatic reset status register (GUTS_AUTORSTSR)              | 1550 |
|      | 20.5.15             | Processor version register (GUTS_PVR)                         | 1552 |
|      | 20.5.16             | System version register (GUTS_SVR)                            | 1552 |
|      | 20.5.17             | Reset control register (GUTS_RSTCR)                           | 1553 |
|      | 20.5.18             | I/O voltage select status register (GUTS_IOVSELSR)            | 1554 |
|      | 20.5.19             | Open drain register (GUTS_CPODRn)                             | 1555 |
|      | 20.5.20             | Data register (GUTS_CPDATn)                                   | 1555 |
|      | 20.5.21             | Direction register (GUTS_CPDIR1n)                             | 1556 |
|      | 20.5.22             | Direction register (GUTS_CPDIR2n)                             | 1557 |
|      | 20.5.23             | Pin assignment register (GUTS_CPPAR1n)                        | 1557 |
|      | 20.5.24             | Pin assignment register (GUTS_CPPAR2n)                        | 1558 |
|      | 20.5.25             | CE Interrupt multiplexing control register n (GUTS_CEIMXCRn)  | 1559 |
|      | 20.5.26             | CE Interrupt mask register (GUTS_CEIMXMASK)                   | 1559 |
|      | 20.5.27             | CE Interrupt polarity register (GUTS_CEIMXPOLAR)              | 1561 |
|      | 20.5.28             | DDR clock disable register (GUTS_DDRCLKDR)                    | 1562 |
|      |                     |                                                               |      |

| Sec  | tion nu  | mber           |                  | Title                                                   | Page |
|------|----------|----------------|------------------|---------------------------------------------------------|------|
|      | 20.5.29  | Clock out      | control register | (GUTS_CLKOCR)                                           | 1563 |
|      | 20.5.30  | ECM contr      | rol register (GU | TTS_ECMCR)                                              | 1564 |
|      | 20.5.31  | SRDS Con       | trol Register 0  | (GUTS_SRDSCR0)                                          | 1565 |
|      | 20.5.32  | SRDS Con       | trol Register 1  | (GUTS_SRDSCR1)                                          | 1567 |
|      | 20.5.33  | SRDS Con       | trol Register 2  | (GUTS_SRDSCR2)                                          | 1568 |
|      | 20.5.34  | SRDS Con       | trol Register 3  | (GUTS_SRDSCR3)                                          | 1570 |
|      | 20.5.35  | SRDS Con       | trol Register 4  | (GUTS_SRDSCR4)                                          | 1573 |
| 20.6 | Function | nal descriptio | n                |                                                         | 1574 |
|      | 20.6.1   | Power mar      | nagement         |                                                         | 1574 |
|      |          | 20.6.1.1       | Relationship     | between both cores and device power management states   | 1575 |
|      |          | 20.6.1.2       | CKSTP_IN0/       | /1_B is not power management                            | 1576 |
|      |          | 20.6.1.3       | Dynamic pow      | ver management                                          | 1576 |
|      |          | 20.6.1.4       | Shutting dow     | n unused blocks                                         | 1576 |
|      |          | 20.6.1.5       | Software-con     | trolled power-down states                               | 1577 |
|      |          |                | 20.6.1.5.1       | Doze mode                                               | 1577 |
|      |          |                | 20.6.1.5.2       | Nap mode                                                | 1577 |
|      |          |                | 20.6.1.5.3       | Sleep mode                                              | 1578 |
|      |          | 20.6.1.6       | Power manag      | gement control fields                                   | 1578 |
|      |          | 20.6.1.7       | Power-down       | sequence coordination                                   | 1579 |
|      |          | 20.6.1.8       | Interrupts and   | l power management                                      | 1580 |
|      |          |                | 20.6.1.8.1       | Interrupts and power management controlled by MSR[WE]   | 1581 |
|      |          |                | 20.6.1.8.2       | Interrupts and power management controlled by POWMGTCSR | 1581 |
|      |          | 20.6.1.9       | Snooping in p    | power down modes                                        | 1582 |
|      |          | 20.6.1.10      | Software cons    | siderations for power management                        | 1582 |
|      |          | 20.6.1.11      | Requirements     | s for reaching and recovering from sleep state          | 1582 |
|      |          |                | Debug            | Chapter 21 Features and Watchpoint Facility             |      |
| 21.1 | Introduc | tion           |                  |                                                         | 1585 |
|      | 21.1.1   | Overview.      |                  |                                                         | 1585 |
|      |          |                |                  |                                                         |      |

| Section number |                  | mber          | Title                                              | Page |
|----------------|------------------|---------------|----------------------------------------------------|------|
|                | 21.1.2 Features. |               |                                                    | 1587 |
|                | 21.1.3           | Modes of      | operation                                          | 1587 |
|                |                  | 21.1.3.1      | Memory debug mode (eLBC and DDR)                   | 1588 |
|                |                  | 21.1.3.2      | DDR SDRAM interface debug mode                     | 1588 |
|                |                  | 21.1.3.3      | Watchpoint monitor modes                           | 1589 |
|                |                  | 21.1.3.4      | Trace buffer modes                                 | 1589 |
| 21.2           | Debug e          | xternal signa | al description                                     | 1589 |
|                | 21.2.1           | Signals ov    | /erview                                            | 1590 |
|                | 21.2.2           | Detailed s    | ignal descriptions                                 | 1591 |
|                |                  | 21.2.2.1      | Debug signals-details                              | 1591 |
|                |                  | 21.2.2.2      | Watchpoint monitor trigger signals-details         | 1592 |
|                |                  | 21.2.2.3      | JTAG test signals-details                          | 1593 |
| 21.3           | Debug M          | Iemory Map    | p/Register Definition                              | 1594 |
|                | 21.3.1           | Watchpoin     | nt monitor control register 0 (debug_WMCR0)        | 1595 |
|                | 21.3.2           | Watchpoin     | nt monitor control register 1 (debug_WMCR1)        | 1597 |
|                | 21.3.3           | Watchpoin     | nt monitor address register (debug_WMAR)           | 1598 |
|                | 21.3.4           | Watchpoin     | nt monitor address mask register (debug_WMAMR)     | 1598 |
|                | 21.3.5           | Watchpoin     | nt monitor transaction mask register (debug_WMTMR) | 1599 |
|                | 21.3.6           | Watchpoin     | nt monitor status register (debug_WMSR)            | 1600 |
|                | 21.3.7           | Trace buff    | fer control register 0 (debug_TBCR0)               | 1601 |
|                | 21.3.8           | Trace buff    | fer control register 1 (debug_TBCR1)               | 1603 |
|                | 21.3.9           | Trace buff    | fer address register (debug_TBAR)                  | 1604 |
|                | 21.3.10          | Trace buff    | fer address mask register (debug_TBAMR)            | 1604 |
|                | 21.3.11          | Trace buff    | fer transaction mask register (debug_TBTMR)        | 1605 |
|                | 21.3.12          | Trace buff    | fer status register (debug_TBSR)                   | 1606 |
|                | 21.3.13          | Trace buff    | fer access control register (debug_TBACR)          | 1607 |
|                | 21.3.14          | Trace buff    | fer access data high register (debug_TBADHR)       | 1607 |
|                | 21.3.15          | Trace buff    | fer access data register (debug_TBADR)             | 1608 |
|                | 21.3.16          | Programm      | ned context ID register (debug_PCIDR)              | 1608 |

| Sec  | Section number |                | Title                                                                                         | Page |  |
|------|----------------|----------------|-----------------------------------------------------------------------------------------------|------|--|
|      | 21.3.17        | Current co     | ontext ID register (debug_CCIDR)                                                              | 1609 |  |
|      | 21.3.18        | Trigger ou     | utput source register (debug_TOSR)                                                            | 1609 |  |
| 21.4 | Function       | al description | on                                                                                            | 1610 |  |
|      | 21.4.1         | Source an      | d target ID                                                                                   | 1610 |  |
|      | 21.4.2         | DDR SDF        | RAM interface debug                                                                           | 1612 |  |
|      |                | 21.4.2.1       | Debug information on debug pins                                                               | 1612 |  |
|      |                | 21.4.2.2       | Debug information on ECC pins                                                                 | 1612 |  |
|      | 21.4.3         | Local bus      | interface debug.                                                                              | 1613 |  |
|      | 21.4.4         | Watchpoin      | nt monitor                                                                                    | 1613 |  |
|      |                | 21.4.4.1       | Watchpoint monitor performance monitor events                                                 | 1614 |  |
|      | 21.4.5         | Trace buff     | fer                                                                                           | 1614 |  |
|      |                | 21.4.5.1       | Traced data formats (as a function of TBCR1[IFSEL])                                           | 1615 |  |
| 21.5 | Initializa     | tion           |                                                                                               | 1616 |  |
|      |                |                | Chapter 22<br>QUICC Engine Block                                                              |      |  |
| 22.1 |                |                |                                                                                               |      |  |
| 22.2 |                |                | C                                                                                             |      |  |
| 22.3 |                |                | ementation details                                                                            |      |  |
|      | 22.3.1         |                | terface                                                                                       |      |  |
|      |                |                | System interface-data paths                                                                   |      |  |
|      |                | 22.3.1.2       | System interface-interrupt configuration                                                      |      |  |
|      | 22.2.2         | 22.3.1.3       | System interface-bus arbitration                                                              |      |  |
|      | 22.3.2         |                | Conf. PAM                                                                                     |      |  |
|      | 22.2.2         | 22.3.2.1       | Configuration-parameter RAM                                                                   |      |  |
|      | 22.3.3         | -              | ing and timers                                                                                |      |  |
|      |                | 22.3.3.1       | Multiplexing and timers-NMSI configuration                                                    |      |  |
|      |                | 22.3.3.2       | Multiplexing and timers-CMX UCC clock route register (CMXUCR3)                                | 1629 |  |
|      |                | 22.3.3.3       | Multiplexing and timers-baud-rate generators (BRGs), BRG configuration registers 1-16 (BRGCn) | 1629 |  |

| Section num | nber Title                                                                                  | Page    |  |
|-------------|---------------------------------------------------------------------------------------------|---------|--|
| 22.3.4      | Unified communications controllers (UCCs)                                                   | 1630    |  |
|             | 22.3.4.1 Unified communications controllers (UCCs)-UCC page base address                    | 1630    |  |
| 22.3.5      | UCC for fast protocols                                                                      | 1631    |  |
| 22.3.6      | UCC Ethernet controller (UEC)                                                               | 1631    |  |
|             | 22.3.6.1 UCC Ethernet controller (UEC)-init Tx, init Rx, and init Tx and Rx parameters comm | and1631 |  |
|             | 22.3.6.2 UCC Ethernet controller (UEC)-multiuser RAM usage                                  | 1632    |  |
| 22.3.7      | IEEE standard 1588 assist                                                                   | 1632    |  |
| 22.3.8      | UTOPIA POS bus controller (UPC)                                                             | 1632    |  |
| 22.3.9      | ATM controller AAL0, AAL1, and AAL5                                                         | 1632    |  |
| 22.3.10     | HDLC controller.                                                                            | 1632    |  |
|             | 22.3.10.1 HDLC controller-introduction.                                                     | 1632    |  |
| 22.3.11     | Transparent controller.                                                                     | 1632    |  |
| 22.3.12     | UCC for slow protocols                                                                      | 1633    |  |
| 22.3.13     | Serial peripheral interface (SPI)                                                           | 1633    |  |
| 22.3.14     | BISYNC mode                                                                                 | 1633    |  |
| 22.3.15     | Serial interface with time-slot assigner.                                                   | 1633    |  |
| 22.3.16     | Serial ATM microcode                                                                        | 1634    |  |
| 22.3.17     | Inverse multiplexing for ATM (IMA)                                                          | 1634    |  |

# Chapter 1 Overview

The chip combines dual Power Architecture® e500v2 processor cores with system logic required for networking, wireless infrastructure, and telecommunications applications.

### 1.1 Overview

This document provides an overview of features and functionality of the QorIQ P1021 integrated processor.

The P1021 combines dual Power Architecture<sup>™</sup> e500v2 processor cores with system logic required for networking, wireless infrastructure, and telecommunications applications.

The P1021 offers an excellent combination of protocol and interface support including dual high-performance CPU cores, a large L2 cache, a DDR2/DDR3 memory controller, three enhanced three-speed Ethernet controllers, a USB 2.0 interface, and two PCI Express controllers. The device also supports the IEEE 1588<sup>™</sup> precision time protocol for network synchronization over Ethernet.

### 1.1.1 Block diagram

The figure below shows the major functional units within the P1021.



Figure 1-1. P1021/1012 block diagram

### 1.1.2 Critical performance parameters

The critical performance parameters are as follows:

- e500v2 core frequency of up to 800 MHz
- 45-nm SOI process technology
- 32-bit DDR2/DDR3 SDRAM memory controller with ECC support
- Supply voltage for core/platform: 1.0 V
- Operating junction temperature (T<sub>j</sub>) range: 0-125°C and -40-125°C (industrial specification)
- 31 x 31 mm 689-pin WB-TePBGA II (wire bond temperature-enhanced plastic BGA)

## 1.1.3 Chip-level features

### Key features include:

- Dual (P1021) or single (P1012) high-performance Power Architecture e500v2 cores
  - 36-bit physical addressing
  - Double-precision floating-point support
  - 32-Kbyte L1 instruction cache and 32-Kbyte L1 data cache for each core
  - 533 MHz to 800 MHz core clock frequency
- 256-Kbyte L2 cache with ECC, also configurable as SRAM and stashing memory
- Three 10/100/1000 Mbps enhanced three-speed Ethernet controllers (eTSECs)
  - TCP/IP acceleration and classification capabilities
  - IEEE 1588 support
  - Lossless flow control
  - MII, RMII, RGMII and SGMII support
- QUICC Engine block
  - 32-bit RISC controller for flexible support of the communications peripherals
  - Serial DMA channel for receive and transmit on all serial channels
  - Four universal communication controllers, supporting 10/100 Mbps Ethernet/ IEEE Std 802.3<sup>TM</sup> (using two RMII and one MII), ATM, HDLC, UART, and BISYNC
- High-speed interfaces (not all available simultaneously):
  - Four SerDes lanes running at 2.5 GHz (multiplexed across controllers)
  - Up to two PCI express interfaces (two x1 or one x1/x2/x4)
  - Two SGMII interfaces
- High-speed USB controller (USB 2.0)
  - Host and device support
  - Enhanced host controller interface (EHCI)
  - ULPI interface to PHY
- Enhanced secure digital host controller (SD/MMC)
- Serial peripheral interface
- Integrated security engine (SEC 3.3.2)
  - Crypto algorithm support includes 3DES, AES, MD5/SHA, RSA/ECC, and FIPS deterministic RNG
  - Single pass encryption/message authentication for common security protocols (IPsec, SSL, SRTP, and WiMax)
  - XOR acceleration
- 16-/32-bit DDR2/DDR3 SDRAM memory controller with ECC support
- Programmable interrupt controller (PIC) compliant with Open-PIC standard
- Four-channel DMA controller
- DUART, timers and two I<sup>2</sup>C controllers

#### P1021 Application examples

- Enhanced local bus controller (eLBC)
- 16 general-purpose I/O signals

These features are described in greater detail in subsequent sections.

### **NOTE**

This device is also available without a security engine. All specifications other than those relating to security apply to the non-security version exactly as described in this document.

# 1.2 P1021 Application examples

The following section provides block diagrams of different applications. The P1021 is a very flexible device and can be configured to meet many system application needs.

Both cores can operate in a symmetric multiprocessing mode to achieve higher performance, or they can run independent operating systems, each performing separate tasks. This flexibility enables application developers to assign distinct processing resources to distinct tasks that need guaranteed performance. For example, one core can manage a data plane and the other a control plane.

The value proposition of a dual-core device is further enhanced by a high degree of peripheral integration of system controllers such as DDR. A device with faster internal buses can entirely replace the system controller where a discrete processor without integration was used previously.

### 1.2.1 Integrated services router

The integrated services routers are typically used in small office to connect and provide secure VPN to headquarters or remote workers. These products have the capability to support routing, Layer 2 switching, security, and IP-PBX.

The figure below shows how the device is ideal for this application, where it enables secure data, voice, and wireless communications in a single easy to manage platform.



Figure 1-2. Integrated services router

### 1.2.2 Home office/micro office gateway

The figure below shows how the device is well suited for the home and micro office market. With its dual-core architecture, it easily supports all required data, voice, security, and wireless services.

Voice framework can be run on one of the cores to support soft DSP functionality, and the QUICC Engine can offload the protocol processing, leaving the second CPU to support exception handling and value added services.



Figure 1-3. Home office/micro office gateway

### 1.3 Architecture overview

This section contains a high-level view of the device architecture.

### 1.3.1 e500v2 cores and memory unit

This device contains two high-performance 32-bit e500v2 cores that implement Power Architecture technology.

In addition to 36-bit physical addressing, this version of the e500 core includes:

- SPE double-precision floating-point instruction set using 64-bit operands
- SPE embedded vector and scalar single-precision floating-point instruction set using 32- or 64-bit operands
- 32-Kbyte L1 instruction cache and 32-Kbyte L1 data cache with parity protection

The device also contains 256 Kbytes of L2 cache/SRAM, as follows:

- Eight-way set-associative cache organization with 32-byte cache lines
- Flexible configuration (can be configured as part cache, part SRAM)
- External masters can force data to be allocated into the cache through programmed memory ranges or special transaction types (stashing).
- SRAM features include the following:
  - I/O devices access SRAM regions by marking transactions as snoopable (global).
  - Regions can reside at any aligned location in the memory map.
  - Byte-accessible ECC uses read-modify-write transaction accesses for smaller-than-cache-line accesses.

### 1.3.2 e500 coherency module (ECM) and address map

The e500 coherency module (ECM) provides a mechanism for I/O-initiated transactions to snoop the bus between the e500v2 cores and the integrated L2 cache in order to maintain coherency across local cacheable memory.

It also provides a flexible switch-type structure for core- and I/O-initiated transactions to be routed or dispatched to target modules on the device.

This device supports a flexible 36-bit physical address map. Conceptually, the address map consists of local space and external address space. The local address map is supported by twelve local access windows that define mapping within the local 36-bit (64-Gbyte) address space.

The device can be made part of a larger system address space through the mapping of translation windows. This functionality is included in the address translation and mapping units (ATMUs). Both inbound and outbound translation windows are provided. The ATMUs allows the device to be part of larger address maps such as that of PCI Express.

### 1.3.3 Integrated security engine (SEC 3.3.2)

The SEC is a modular and scalable security core optimized to process all the algorithms associated with IPsec, IKE, SSL/TLS, iSCSI, SRTP, IEEE 802.11i<sup>®</sup>, IEEE 802.16<sup>®</sup> (WiMAX), and IEEE 802.1AE<sup>®</sup> Std. (MACSec).

Although it is not a protocol processor, the SEC is designed to perform multi-algorithmic operations (for example, 3DES-HMAC-SHA-1) in a single pass of the data. The version of the SEC used in this device is specifically capable of performing single-pass security cryptographic processing for SSL 3.0, SSL 3.1/TLS 1.0, IPSec, SRTP, and 802.11i.

SEC features include the following:

#### **Architecture overview**

- Compatible with code written for the Freescale MPC8548E, MPC8555E, and MPC8541E devices
- XOR engine for parity checking in RAID storage applications
- Four crypto channels, each supporting multi-command descriptor chains
- Cryptographic execution units:
  - PKEU-public key execution unit
  - DEU-data encryption standard execution unit
  - AESU-advanced encryption standard unit
  - MDEU-message digest execution unit
  - CRCU-cyclical redundancy check unit
  - RNGU-random number generator

For more information, see Security Engine (SEC) 3.3.2 Engineering Bulletin (EB748).

### 1.3.4 Enhanced three-speed Ethernet controllers

This device has three on-chip enhanced three-speed Ethernet controllers (eTSECs). The eTSECs incorporate a media access control (MAC) sublayer that supports 10- and 100-Mbps and 1-Gbps Ethernet/802.3 networks with MII, RMII, SGMII and RGMII physical interfaces.

The eTSECs support programmable CRC generation and checking, RMON statistics, and jumbo frames of up to 9.6 Kbytes. Frame headers and buffer descriptors can be forced into the L2 cache to speed classification or other frame processing. They are designed to comply with IEEE Std. 802.3<sup>TM</sup>, 802.3u, 802.3x, 802.3z, 802.3ac, and 802.3ab.

The buffer descriptors are based on the MPC8540 three-speed Ethernet controller programming model. Each eTSEC can emulate a PowerQUICC III TSEC, allowing existing driver software to be re-used with minimal change.

Some of the key features of these controllers include:

• Flexible configuration for multiple PHY interface configurations. The table below lists available configurations.

Table 1-1. eTSEC configuration options1

| eTSEC1                 | eTSEC2  | eTSEC3           |
|------------------------|---------|------------------|
| MII     RMII     RGMII | • SGMII | RMII RGMII SGMII |

- 1. The parallel interfaces must use the same voltage.
  - TCP/IP acceleration and QoS features:

- IP v4 and IP v6 header recognition on receive
- IP v4 header checksum verification and generation
- TCP and UDP checksum verification and generation
- Per-packet configurable acceleration
- Recognition of VLAN, stacked (queue in queue) VLAN, 802.2, PPPoE session, MPLS stacks, and ESP/AH IP-security headers
- Transmission from up to eight physical queues
- Reception to up to eight physical queues
- Full- and half-duplex Ethernet support (1000 Mbps supports only full duplex):
  - IEEE Std. 802.3 full-duplex flow control (automatic PAUSE frame generation or software-programmed PAUSE frame generation and recognition)
- IEEE Std. 802.1 virtual local area network (VLAN) tags and priority
- VLAN insertion and deletion
  - Per-frame VLAN control word or default VLAN for each eTSEC
  - Extracted VLAN control word passed to software separately
- Programmable Ethernet preamble insertion and extraction of up to 7 bytes
- MAC address recognition
- Ability to force allocation of header information and buffer descriptors into L2 cache
- Interrupt virtualization
  - Each ring mappable to one of two separate groups for interrupt and BD management; each group associated by software with a CPU.
  - Separate address spaces per group and for MDIO
  - Interrupt coalescing controls per ring in multi-group mode
- Modified Weighted Round-Robin Queuing (MWRR)
- Advanced hashing logic

# 1.3.5 Universal serial bus (USB) 2.0 controller

The USB 2.0 controller provides point-to-point connectivity complying with the *Universal Serial Bus Revision 2.0 Specification*. The USB controller can be configured to operate as a stand-alone host, stand-alone device, or both host and device functions operating simultaneously.

The host and device functions are both configured to support the following types of USB transfers:

- Bulk
- Control
- Interrupt
- Isochronous

Other controller features are as follows:

#### **Architecture overview**

- Supports USB dual-role operation and can be configured as host or device
- Supports operation as a stand-alone USB device
  - Supports one upstream facing port
  - Supports six programmable USB endpoints
- Supports operation as a stand-alone USB host controller
  - Supports USB root hub with one downstream-facing port
  - Enhanced host controller interface (EHCI) compatible
- Supports high-speed (480 Mbps), full-speed (12 Mbps), and low-speed (1.5 Mbps) operations
- Supports external PHY with UTMI+ low-pin interface (ULPI)

### 1.3.6 Enhanced secure digital host controller

The enhanced secure digital host controller (eSDHC) provides an interface between the host system and SD/MMC cards. The eSDHC acts as a bridge, passing host bus transactions to SD/MMC cards by sending commands and performing data accesses to or from the cards. It handles SD/MMC protocols at the transmission level. Booting from onchip ROM is supported through the eSDHC, as described in eSDHC boot.

The eSDHC includes the following features:

- SD bus clock frequency up to 50 MHz
- Supports 1-/4-bit SD mode, 1-/4-bit MMC modes
- Up to 200 Mbps data transfer for SD/MMC cards using 4 parallel data lines
- Supports single- and multi-block read and write
- Supports write protection switch for write operations
- Supports synchronous and asynchronous abort
- Supports pause during the data transfer at a block gap
- Supports Auto CMD12 for multi-block transfer
- Host can initiate non-data transfer commands while the data transfer is in progress
- Embodies a fully configurable 128 x 32-bit FIFO for read/write data
- Supports internal DMA capabilities

# 1.3.7 Serial peripheral interface (SPI)

The serial peripheral interface (SPI) allows the device to exchange data between other PowerQUICC family devices, Ethernet PHYs for configuration, and peripheral devices such as EEPROMs, real-time clocks, A/D converters, and ISDN devices.

The SPI is a full-duplex, synchronous, character-oriented channel that supports a four-wire interface (receive, transmit, clock, and slave select). The SPI block consists of transmitter and receiver sections, an independent baud-rate generator, and a control unit. This device also has the ability to boot from an SPI serial flash device.

The SPI receiver and transmitter each have a FIFO of 32 bytes to support more efficient transfers to and from SPI devices. The SPI interface supports RapidS for Atmel devices as well as Winbond devices dual read commands; in this mode the SPI uses two bits in parallel for reads.

### 1.3.8 DDR SDRAM controller

This device supports DDR2 and DDR3 SDRAM. The memory interface controls main memory accesses and provides for a maximum of 8 Gbytes of main memory.

The device supports a variety of SDRAM configurations. SDRAM banks can be built using directly-attached memory devices. Sixteen multiplexed address signals provide for device densities from 32 Mbits to 4 Gbits. Two chip select signals support up to two banks of memory. The device supports bank sizes from 32 Mbytes to 4 Gbytes. Five data masks (MDM[0:3], MDM8) are used to provide byte selection for memory bank writes.

The device can be configured to retain the currently active SDRAM page for pipelined burst accesses. Page mode support of up to 32 simultaneously open pages can dramatically reduce access latencies for page hits. Depending on the memory system design and timing parameters, using page mode can save 3 to 4 clock cycles from subsequent burst accesses that hit in an active page.

Using ECC, the device detects and corrects all single-bit errors and detects all double-bit errors and all errors within a nibble.

The device can invoke a level of system power management by asserting the MCKE SDRAM signal on-the-fly to put the memory into a low-power sleep mode.

The device offers both hardware and software options to support battery-backed main memory. In addition, the DDR controller offers an initialization bypass feature which system designers may use to prevent re-initialization of main memory during system power-on following abnormal shutdown.

### 1.3.9 High-speed I/O interfaces

This device supports the SGMII and PCI Express high-speed I/O interface standards.

### 1.3.9.1 PCI Express interfaces

This device supports two PCI Express interfaces that are compatible with the *PCI* Express Base Specification Revision 1.0a. They are configurable at boot time to act as either root complex or endpoint.

The physical layer of the PCI Express interface operates at a transmission rate of 2.5 Gbaud (data rate of 2.0 Gbps) per lane. The theoretical unidirectional peak bandwidth is 2 Gbps per lane. Receive and transmit ports operate independently, resulting in an aggregate theoretical bandwidth of 4 Gbps per lane.

Other features of the PCI Express interface include:

- Supports two PCI Express interfaces with up to x4 link width
- Both 32- and 64-bit addressing and 256-byte maximum payload size
- Full 64-bit decode with 36-bit wide windows

### 1.3.9.2 SGMII

The serial gigabit media independent interface (SGMII) is a high-speed interface linking the Ethernet controller with an Ethernet PHY. SGMII uses differential signaling for electrical robustness.

Only four signals are required: receive data and its inverse, and send data and its inverse. No clock signals are required.

### 1.3.9.3 High-speed interface multiplexing

The table below shows the supported high-speed interface configurations. The desired configuration must be selected at power-on reset.

|          | Lanes    |        |        |             | aud         |
|----------|----------|--------|--------|-------------|-------------|
| 0        | 1        | 2      | 3      | Lane0/Lane1 | Lane2/Lane3 |
| PEX1: x1 | off      | off    | off    | 2.5         | -           |
|          | PEX      | 1: x4  |        | 2           | .5          |
| PEX1: x1 | PEX2: x1 | SGMII2 | SGMII3 | 2.5         | 1.25        |
| PEX      | 1: x2    | SGMII2 | SGMII3 | 2.5         | 1.25        |

Table 1-2. Supported high-speed interface combinations

### 1.3.10 QUICC engine subsystem

The QUICCEngine technology is a versatile communications complex that integrates several communications peripheral controllers.

It provides on-chip system design for a variety of applications, particularly applications in communications and networking systems. The QUICC Engine technology has the following features:

- One 32-bit RISC controller for flexible support of the communications peripherals
- Serial DMA channel for receive and transmit on all serial channels
- Four universal communication controllers (UCCs) supporting the following protocols and interfaces (not all of them simultaneously):
  - Two 10/100 Mbps Ethernet/IEEE Std. 802.3 interfaces, using RMII
  - ATM protocol through UTOPIA
  - HDLC and Transparent controllers up to 50 Mbps full-duplex; HDLC bus up to 10 Mbps
  - UART and asynchronous HDLC
  - BISYNC up to 2 Mbps
  - QUICC multichannel controller (QMC) for 128 TDM channels
- One UTOPIA L2 interface supporting 31 multi-PHY addresses
- One serial peripheral interface (SPI)
- Four TDM interfaces, with T1/E1/J1/E3 or DS-3 serial interfaces

In addition, the following protocols are supported:

- ATM SAR up to 155 Mbps (OC-12) full duplex, with ATM traffic shaping (ATF TM4.1) for up to 256 ATM connections
- ATM AAL1 structured and unstructured circuit emulation service (CES 2.0)
- IMA and ATM transmission convergence sublayer
- ATM OAM handling features compatible with ITU-TI.610
- PPP, multilink (ML-PPP), multiclass (MC-PPP), and PPP mux in accordance with the following RFCs: 1661, 1662, 1990, 2686, 3153
- IP termination support for IPv4 and IPv6 packets including TOS, TTL, and header checksum processing
- Support for ATM statistics and Ethernet RMON/MIB statistics.
- 128 channels of HDLC/Transparent or 64 channels of SS7
- Up to 4 TDM ports
- IEEE 1588 V2 support
- RAM based microcode

### 1.3.11 Programmable interrupt controller (PIC)

The PIC implements the logic and programming structures of the OpenPIC architecture, providing for external interrupts (with fully nested interrupt delivery), message interrupts, internal-logic driven interrupts, and global high-resolution timers.

Up to 16 programmable interrupt priority levels are supported. The PIC can be bypassed to allow use of an external interrupt controller.

# 1.3.12 DMA, I<sup>2</sup>C, DUART, and enhanced local bus controller

This device provides an integrated four-channel DMA controller, which can transfer data between any of its I/O or memory ports or between two devices or locations on the same port.

The DMA controller can be used as follows:

- To chain (both extended and direct) through local memory-mapped chain descriptors.
- To handle misaligned transfers as well as stride transfers and complex transaction chaining.
- To specify local attributes such as snoop and L2 write stashing.

There are two I<sup>2</sup>C controllers. These synchronous, multimaster buses can be connected to additional devices for expansion and system development.

The DUART supports full-duplex operation and is compatible with the PC16450 and PC16550 programming models. Both the transmitter and receiver support 16-byte FIFOs.

The enhanced local bus controller (eLBC) port allows connection with a wide variety of external memories, DSPs, and ASICs. Three separate state machines share the same external pins and can be programmed separately to access different types of devices. The general-purpose chip select machine (GPCM) controls accesses to asynchronous devices using a simple handshake protocol. The user programmable machine (UPM) can be programmed to interface to synchronous devices or custom ASIC interfaces. The NAND Flash control machine (FCM) further extends interface options. Each chip select can be configured so that the associated chip interface can be controlled by the GPCM, UPM, or FCM controller. All may exist in the same system. The local bus controller supports the following features:

- Multiplexed 26-bit address and data bus operating up to 83 MHz
- Eight chip selects support eight external slaves
- Up to eight-beat burst transfers

- 16- and 8-bit port sizes controlled by on-chip memory controller
- Three protocol engines available on a per-chip-select basis
- Parity support
- Default boot ROM chip select with configurable bus width (8 or 16 bits)
- Supports zero-bus-turnaround (ZBT) RAM
- FCM supports NAND Flash, GPCM supports NOR Flash

### 1.3.13 Device boot locations

This device may be configured to boot using one of the following interfaces:

- DDR2/DDR3 memory controller
- Any PCI Express interface
- Enhanced local bus interface (using the GPCM or FCM)
- SPI Flash
- SD/MMC Flash

## 1.3.14 Boot sequencer

This device provides a boot sequencer that uses the  $I^2C1$  interface to access an external serial ROM and loads the data into the device's configuration registers.

The boot sequencer is enabled by a configuration pin sampled at the negation of the devices's hardware reset signal. If enabled, the boot sequencer holds the processor cores in reset until the boot sequence is complete. If the boot sequencer is not enabled, the processor cores exit reset and fetches boot code in default configurations.

## 1.3.15 System performance monitor

The performance monitor facility supports eight 32-bit counters that can count up to 512 counter-specific events.

It supports duration and quantity threshold counting and a burstiness feature that permits counting of burst events with a programmable time between bursts.

**Architecture overview** 

# **Chapter 2 Memory Map**

This chapter describes the mechanisms that define the device memory map-the local access windows (LAWs), the address translation and mapping units (ATMUs), and the configuration, control, and status registers (CCSRs).

### 2.1 Overview

This chapter describes the mechanisms that define the device memory map-the local access windows (LAWs), the address translation and mapping units (ATMUs), and the configuration, control, and status registers (CCSRs).

There are several address domains within the device, including the following:

- Logical, virtual, and physical (real) address spaces within the e500 core
- Internal local address space
- Internal configuration, control, and status register (CCSR) address space
- External memory, I/O, and configuration address spaces of the PCI Express link

The MMU in the e500 core handles translation of logical (effective) addresses into virtual addresses and ultimately to the physical addresses for the local address space.

The local address map refers to the physical 36-bit address space seen by the e500 core as it accesses memory and I/O space. The DMA engines also see this same local address map. All memory controlled by the DDR and local bus controllers exists in this address map, as do all memory-mapped configuration, control, and status registers (CCSRs). The local address map is defined by a set of twelve local access windows (LAWs). Each of these windows maps a region of the local address space to a specified target interface, such as the DDR controller, enhanced local bus controller, PCI Express controller, or other targets. The internal configuration, control, and status registers (CCSRs) for all the functional blocks are located in the local memory space at a specific CCSR window.

### Configuration, control, and status registers

If the target mapping performed by the local access windows directs the transaction to one of the external interfaces (as an outbound read or write), the transaction is then mapped into that interface's external address space by address translation and mapping unit (ATMU) windows associated with the external interface. Outbound ATMUs perform the mapping from the local 36-bit address space to the address space of external interface; inbound ATMU windows perform the address translation from the external address space to the local address space.

## 2.2 Configuration, control, and status registers

All of the memory-mapped configuration, control, and status registers (CCSRs) in this device are contained within a 1-Mbyte address region.

To allow for flexibility, the CCSR block is relocatable in the local address space.

The local address map location of the CCSR block is controlled by the configuration, control, and status base address register (CCSRBAR); see Configuration, control, and status registers base address register (reset\_CCSRBAR). The default address for CCSRBAR is  $0x0_FF70_0000$  (or 4 Gbytes - 9 Mbytes). No address translation is performed for CCSR space, so there is no associated translation address register. The CCSR window is always enabled with a fixed size of 1 Mbyte; no other attributes are attached, so there is no associated window attribute register.

### NOTE

The CCSR window must not overlap a LAW that maps to the DDR controller. Otherwise, undefined behavior occurs.

An example of a top-level memory map with the default location of the configuration, control, and status registers is shown in the figure below.



Figure 2-1. CCSR space

## 2.2.1 Accessing CCSR memory from the local processor

When the local e500 core is used to configure CCSR space, the CCSR memory space should typically be marked as cache-inhibited and guarded.

In addition, many configuration registers affect accesses to other memory regions; therefore writes to these registers must be guaranteed to have taken effect before accesses are made to the associated memory regions.

To guarantee that the results of any sequence of writes to configuration registers are in effect, the final configuration register write should be chased by a read of the same register, and that should be followed by a SYNC instruction. Then accesses can safely be made to memory regions affected by the configuration register write.

## 2.2.2 Accessing CCSR memory from external masters

In addition to being accessible by the e500 processor, the CCSRs are accessible from the external PCI Express interface.

### Configuration, control, and status registers

This allows external masters on the I/O ports to configure the device.

External masters do not need to know the location of the CCSR memory in the local address map. Rather, they access the CCSR region of the local memory map through a window defined by a register in the interface's programming model that is accessible to the external master from its external memory map.

The PCI Express base address for accessing the local CCSR memory is selectable through the PCI Express configuration and status register base address register (PEXCSRBAR), at offset 0x10. An external PCI Express master sets this register by performing a PCI Express configuration cycle to this device. Subsequent memory accesses by a PCI Express master to the PCI Express address range indicated by PEXCSRBAR are translated to the local CCSR address indicated by the current setting of CCSRBAR.

## 2.2.3 Organization of CCSR space

As shown in , the CCSR space is divided into the following groups-general utilities, programmable interrupt controller (PIC), and device-specific utilities registers.

## 2.2.3.1 General utilities registers

The general utilities registers are the functional block-specific registers that occupy the first 256 Kbytes of CCSR space.

Each functional block is allocated a 4-Kbyte address range for its registers within the general utilities space. The figure below shows the layout of the general utilities registers.



Figure 2-2. General utilities register map within CCSR space

## 2.2.3.1.1 General utilities register organization

The figure below shows the typical organization of registers inside the 4-Kbyte register space allocated to an individual functional block.

Starting at the block base address, the first 3 Kbytes are available for general registers. If the functional block has associated ATMUs, the next 512 bytes are dedicated to address translation and mapping registers. If a functional block has error management registers, they are typically placed starting at offset 0xE00 from the block base address, and any debug registers are typically placed in the final 256 bytes of the block's register space starting at offset 0xF00.



Figure 2-3. General utility register block

#### NOTE

Refer to detailed register descriptions for each functional block for exact locations, sizes, and access requirements.

## 2.2.3.2 Programmable interrupt controller registers

The programmable interrupt controller (PIC) follows the OpenPIC programming model which requires a larger register address space than the 4 Kbytes allocated to other blocks within the general utilities space.

For this reason, the PIC is allocated the second 256 Kbytes of CCSR space, beginning at offset 0x4\_0000 from CCSRBAR.

The layout of the PIC register space is shown in the figure below. Note that the PIC registers should only be accessed with 32-bit accesses.



Figure 2-4. PIC register map within CCSR space

## 2.2.4 QUICC engine block and CCSR

The QUICC Engine block uses 192 Kbytes of configuration memory.

In addition to a 64-Kbyte region for configuration registers, two separate 16-Kbyte parameter RAM regions are defined as well as a 32-Kbyte instruction RAM region.

The figure below shows the QUICC Engine block's mapping to the CCSR memory block.



Figure 2-5. QUICC engine block mapping to configuration, control, and status memory block

### NOTE

See Accessing configuration, control, and status registers The location for the CCSR Register Memory Block is programmable using the CCSR base address register (CCSRBAR). The default base address for the configuration, control, and status registers is 0xFF70\_0000 (CCSRBAR = 0x000F\_F700).

## 2.2.5 Device-specific utilities registers

The device-specific utilities registers control functions that are not particular to a functional unit but to the device as a whole; they occupy the highest 256 Kbytes of CCSR space.

The device-specific utilities registers consist of power management, performance monitors, and device-wide debug utilities.

The figure below shows the layout of the device-specific utilities registers. Note that the device-specific registers are accessible with 32-bit accesses only. Transactions of a size other than 32-bits are considered programming errors and the operation is undefined.



Figure 2-6. P1021 Device-specific register map within CCSR space

## 2.2.6 CCSR address map

The full register address of any CCSR is comprised of the CCSR window base address, specified in CCSRBAR (default address 0x0\_FF70\_0000), plus the functional block base address, plus the specific register's offset within that block.

The table below shows the location of the functional block base addresses for the entire CCSR space. Cross-references are provided to the CCSR maps for each individual block.

Table 2-1. CCSR block base address map

| Block Base Address<br>(Hex) | Block                                       | CCSR Map                                                     | Comments                                                                           |
|-----------------------------|---------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------|
| General Utilities (0x0_00   | 000-0x3_FFFF)                               | •                                                            |                                                                                    |
| 0x0_0000- 0x0_0FFF          | Local configuration control                 | ECM memory map/<br>register definition                       | -                                                                                  |
|                             | Local access window                         | Local Access Window<br>Registers                             | -                                                                                  |
| 0x0_1000- 0x0_1FFF          | ECM (e500 coherency module)                 | ECM memory map/<br>register definition                       | -                                                                                  |
| 0x0_2000- 0x0_2FFF          | DDR memory controller                       | DDR memory map/<br>register definition                       | -                                                                                  |
| 0x0_3000- 0x0_3FFF          | I <sup>2</sup> C controllers                | I2C memory map/<br>register definition                       | I <sup>2</sup> C controller 1: 0x0_3000<br>I <sup>2</sup> C controller 2: 0x0_3100 |
| 0x0_4000- 0x0_4FFF          | DUART                                       | DUART memory map/<br>register definition                     | UART 0: 0x0_4500<br>UART 1: 0x0_4600                                               |
| 0x0_5000- 0x0_5FFF          | Enhanced local bus controller (eLBC)        | Enhanced Local Bus<br>Controller (eLBC)<br>Memory Map        | -                                                                                  |
| 0x0_6000- 0x0_6FFF          | Reserved                                    | -                                                            | -                                                                                  |
| 0x0_7000- 0x0_7FFF          | Enhanced serial peripheral interface (eSPI) | Enhanced serial<br>peripheral interface<br>(eSPI) memory map | -                                                                                  |
| 0x0_8000- 0x0_8FFF          | Reserved                                    | -                                                            | -                                                                                  |
| 0x0_9000- 0x0_9FFF          | PCI Express controller 2                    | PCI Express memory-<br>mapped registers                      | -                                                                                  |
| 0x0_A000- 0x0_AFFF          | PCI Express controller 1                    | PCI Express memory-<br>mapped registers                      | -                                                                                  |
| 0x0_B000- 0x0_EFFF          | Reserved                                    | -                                                            | -                                                                                  |
| 0x0_F000- 0x0_FFFF          | QUICC Engine Interrupt block                | _1                                                           | -                                                                                  |
| 0x1_0000- 0x1_FFFF          | Reserved                                    |                                                              | -                                                                                  |
| 0x2_0000- 0x2_0FFF          | L2 Cache                                    | L2_Cache memory map/register definition                      | -                                                                                  |
| 0x2_1000- 0x2_1FFF          | DMA controller                              | DMA controller memory                                        | DMA 0: 0x2_1100                                                                    |
|                             |                                             | map                                                          | DMA 1: 0x2_1180                                                                    |
|                             |                                             |                                                              | DMA 2: 0x2_1200                                                                    |
|                             |                                             |                                                              | DMA 3: 0x2_1280                                                                    |
|                             |                                             |                                                              | General Status: 0x2_1300                                                           |
| 0x2_2000-0x2_2FFF           | USB controller (dual role)                  | USB memory map/<br>register definition                       |                                                                                    |
| 0x2_3000- 0x2_3FFF          | Reserved                                    |                                                              |                                                                                    |
| 0x2_4000- 0x2_6FFF          | eTSEC MDIO                                  | eTSEC memory map/                                            | eTSEC 1 MDIO: 0x2_4000                                                             |
|                             |                                             | register definition                                          | eTSEC 2 MDIO: 0x2_5000                                                             |
|                             |                                             |                                                              | eTSEC 3 MDIO: 0x2_6000                                                             |
| 0x2_7000- 0x2_DFFF          | Reserved                                    |                                                              | -                                                                                  |

## Table 2-1. CCSR block base address map (continued)

| Block Base Address<br>(Hex) | Block                                     | CCSR Map                                                              | Comments                                |
|-----------------------------|-------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------|
| 0x2_E000- 0x2_EFFF          | eSDHC                                     | Enhanced Secure<br>Digital Host Controller<br>(eSDHC) Memory Map      | -                                       |
| 0x2_F000- 0x2_FFFF          | Reserved                                  | -                                                                     | -                                       |
| 0x3_0000- 0x3_FFFF          | Security Engine (SEC)                     | See Security Engine<br>(SEC) 3.3.2<br>Engineering Bulletin<br>(EB748) | -                                       |
| Programmable Interrupt      | Controller (PIC) (0x4_0000-0x7            | 7_FFFF)                                                               |                                         |
| 0x4_0000- 0x7_FFFF          | PIC                                       | PIC memory map/                                                       | Global registers: 0x4_0000              |
|                             |                                           | register definition                                                   | Interrupt source registers: 0x5_0000    |
|                             |                                           |                                                                       | Processor (per-CPU) registers: 0x6_0000 |
| QUICC Engine Block (0x      | 8_0000-0xA_FFFF)                          |                                                                       |                                         |
| 0x8_0000- 0x8_FFFF          | QUICC Engine Internal<br>Registers        | QEIWRM                                                                |                                         |
| 0x9_0000- 0x9_5FFF          | QUICC Engine MURAM                        | QEIWRM                                                                |                                         |
| 0x9_6000- 0xA_FFFF          | Reserved                                  |                                                                       |                                         |
| eTSEC (0xB_0000-0xB_        | 6FFF)                                     |                                                                       |                                         |
| 0xB_0000- 0xB_2FFF          | eTSEC group 0                             | eTSEC memory map/                                                     | eTSEC 1 group 0: 0xB_0000               |
|                             |                                           | register definition                                                   | eTSEC 2 group 0: 0xB_1000               |
|                             |                                           |                                                                       | eTSEC 3 group 0: 0xB_2000               |
| 0xB_3000- 0xB_3FFF          | Reserved                                  | -                                                                     | -                                       |
| 0xB_4000- 0xB_6FFF          | eTSEC group 1                             | eTSEC memory map/                                                     | eTSEC 1 group 1: 0xB_4000               |
|                             |                                           | register definition                                                   | eTSEC 2 group 1: 0xB_5000               |
|                             |                                           |                                                                       | eTSEC 3 group 1: 0xB_6000               |
| Device-Specific Utilities ( | 0xE_0000-0xF_FFFF)                        |                                                                       |                                         |
| 0xE_0000- 0xE_0FFF          | Global utilities                          | GUTS Memory Map/<br>Register Definition                               | -                                       |
| 0xE_1000- 0xE_1FFF          | Performance monitor                       | PERFMON Memory<br>Map/Register Definition                             | -                                       |
| 0xE_2000- 0xE_2FFF          | Debug/Watchpoint monitor and trace buffer | Debug Memory Map/<br>Register Definition                              | -                                       |
| 0xE_3000- 0xE_30FF          | SerDes control                            | GUTS Memory Map/<br>Register Definition                               | -                                       |
| 0xE_3100- 0xE_FFFF          | Reserved                                  | -                                                                     | -                                       |
| 0xF_0000- 0xF_FFFF          | Internal boot ROM <sup>2</sup>            | -                                                                     | -                                       |

- 1. Refer to the *QUICC Engine™ Block Reference Manual with Protocol Interworking*, QEIWRM.
- 2. Even though it is allocated 64 Kbytes in the memory space, only 8 Kbytes of internal boot ROM is physically implemented. This is located at the upper 8 Kbytes of the allocated 64 Kbyte address space, from CCSR offset 0xF\_E000 to 0xF\_FFFF.

### 2.3 Local access windows

The local address map is defined by a set of twelve local access windows (LAWs).

Each of these windows maps a programmable 4-Kbyte to 32-Gbyte region of the local 36-bit address space to a specified target interface, such as the DDR controller, local bus controller, PCI Express controllers, or other targets. This allows the internal interconnections of the device to route a transaction from its source to the proper target.

Each LAW is defined by a base address register which specifies the starting address for the window, and an attribute register which specifies whether the mapping is enabled, the size of the window, and the target interface for that window. Note that the LAWs do not perform any address translation, and therefore, there are no corresponding translation address registers. The local access window registers exist as part of the local access block in the general utilities registers in CCSR space.

With the exception of configuration space (mapped by CCSRBAR) and the default boot ROM space, all addresses used by the system must be mapped by an LAW. This includes addresses that are mapped by inbound ATMU windows. Thus, target mappings of the local access windows and the inbound ATMU windows must be consistent.

### 2.3.1 Precedence of local access windows

If two or more LAWs overlap, the lower numbered window takes precedence.

For instance, consider two LAWs, set up as shown in the table below.

 LAW
 Base Address
 Size
 Target Interface

 1
 0x0\_7FF0\_0000
 1 Mbyte
 0b00100 (local bus controller-LBC)

 2
 0x0\_0000\_0000
 2 Gbytes
 0b01111 (DDR controller)

Table 2-2. Overlapping local access windows

In this case, LAW 1 governs the mapping of the 1-Mbyte region from 0x0\_7FF0\_0000 to 0x0\_7FFF\_FFF, even though the window described in LAW 2 also encompasses that memory region.

## 2.3.2 Configuring local access windows

Once a local access window is enabled, it should not be modified while any device in the system may be using the window.

Neither should a new window be used until the effect of the write to the window is visible to all blocks that use the window. This can be guaranteed by completing a read of the last LAW configuration register before enabling any other devices to use the window. For example, if LAWs 0-3 are being configured in order during the initialization process, the last write (to LAWAR3) should be followed by a read of LAWAR3 before any devices try to use any of these windows. If the configuration is being performed by the e500 core, the read of LAWAR3 should be followed by an isync instruction.

## 2.3.3 Distinguishing local access windows from other mapping functions

It is important to distinguish between the mapping function performed by the LAWs and the additional mapping functions that occur at the target interfaces.

The LAWs define how a transaction is routed through the device's internal interconnects from the transaction's source to its target. After the transaction has arrived at its target interface, that interface controller may perform additional mapping. For instance, the DDR controller has chip select registers that map a memory request to a particular external device. Similarly, the local bus controller has base registers that perform a similar function. The PCI Express interface has an outbound address translation and mapping unit (ATMU) that maps the local address into an external address space.

These other mapping functions are configured by programming the CCSRs of the individual interfaces. Note that there is no need to have a one-to-one correspondence between LAWs and chip select regions or outbound ATMU windows. A single LAW can be further decoded to any number of chip selects or to any number of outbound ATMU windows at the target interface.

## 2.3.4 Illegal interaction between local access windows and DDR chip selects

If a local access window maps an address to an interface other than the DDR controller, there should not be a valid chip select configured for the same address in the DDR controller.

Because DDR chip select boundaries are defined by a beginning and ending address, it is easy to define them so that they do not overlap with LAWs that map to other interfaces.

## 2.3.5 Local address map example

The figure below shows what a typical local address map might look like.



Figure 2-7. Local address map example

The table below shows the corresponding set of LAW settings for the example shown in the figure above.

Window **Base Address** Size **Target Interface** TRGT 0 0x0\_0000\_0000 2 Gbytes DDR controller 0b01111 1 0x0\_8000\_0000 1 Mbyte Enhanced local bus controller (eLBC)-FCM 0b00100 2 0b00010 0x0\_A000\_0000 256 Mbytes PCI Express 1 3 0x0\_B000\_0000 256 Mbytes PCI Express 2 0b00001 4 0x0\_C000\_0000 Enhanced local bus controller (eLBC)-DSP 0b00100 256 Mbytes 5-9 Unused

Table 2-3. Local access window settings example

In this example, it is not necessary to use a LAW to specify the location of the boot ROM. See Boot page translation, for more information.

## 2.4 Local Access Window Registers

The local access window registers are accessed by reading and writing to an address comprised of the base address (specified in the CCSRBAR), plus the block base address, plus the offset of the specific register to be accessed. For the LAWs, the block base address is  $0x0\_0000$ .

Note that all LAW registers should only be accessed a word (4-bytes) at a time. The table below shows the memory map for the LAW registers.

### LAW memory map

| Offset<br>address<br>(hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-----------------------------------------------------------|--------------------|--------|-------------|------------------|
| C08                        | Local access window n base address register (LAW_LAWBAR0) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| C10                        | Local access window n attribute register (LAW_LAWAR0)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| C28                        | Local access window n base address register (LAW_LAWBAR1) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| C30                        | Local access window n attribute register (LAW_LAWAR1)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| C48                        | Local access window n base address register (LAW_LAWBAR2) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| C50                        | Local access window n attribute register (LAW_LAWAR2)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| C68                        | Local access window n base address register (LAW_LAWBAR3) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| C70                        | Local access window n attribute register (LAW_LAWAR3)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| C88                        | Local access window n base address register (LAW_LAWBAR4) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| C90                        | Local access window n attribute register (LAW_LAWAR4)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| CA8                        | Local access window n base address register (LAW_LAWBAR5) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| CB0                        | Local access window n attribute register (LAW_LAWAR5)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| CC8                        | Local access window n base address register (LAW_LAWBAR6) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| CD0                        | Local access window n attribute register (LAW_LAWAR6)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| CE8                        | Local access window n base address register (LAW_LAWBAR7) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| CF0                        | Local access window n attribute register (LAW_LAWAR7)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| D08                        | Local access window n base address register (LAW_LAWBAR8) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| D10                        | Local access window n attribute register (LAW_LAWAR8)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |

### LAW memory map (continued)

| Offset address (hex) | Register name                                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------------------------|--------------------|--------|-------------|------------------|
| D28                  | Local access window n base address register (LAW_LAWBAR9)  | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| D30                  | Local access window n attribute register (LAW_LAWAR9)      | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| D48                  | Local access window n base address register (LAW_LAWBAR10) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| D50                  | Local access window n attribute register (LAW_LAWAR10)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |
| D68                  | Local access window n base address register (LAW_LAWBAR11) | 32                 | R/W    | 0000_0000h  | 2.4.1/90         |
| D70                  | Local access window n attribute register (LAW_LAWAR11)     | 32                 | R/W    | 0000_0000h  | 2.4.2/90         |

## 2.4.1 Local access window n base address register (LAW\_LAWBARn)

The LAWBARn registers define the 24 high-order address bits that fixes the location of each window in the local address space. Note that the minimum size of any LAW is 4 Kbytes, so the 12 lowest-order bits of the base address cannot be specified. The figure below shows the bit fields of the LAWBARn registers.

Address: 0h base + C08h offset + (32d × i), where i=0d to 11d



### LAW\_LAWBARn field descriptions

| Field    | Description                                                                                                                                                                      |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>- | This field is reserved. Reserved                                                                                                                                                 |
|          | Identifies the 24 most-significant address bits of the base of local access window n. The specified base address must be aligned to the window size, as defined by LAWARn[SIZE]. |

## 2.4.2 Local access window n attribute register (LAW\_LAWARn)

The LAWAR*n* registers are used to enable specific local access windows, define their size and specify the target interface. The figure below shows the bit fields of the LAWAR*n* registers.

The target interface for each LAW is specified using the encodings shown in the table below. Note that configuration registers are mapped by the windows defined by CCSRBAR. The CCSR mapping supersedes local access window mappings, so configuration registers do not appear as a target for local access windows.

**Table 2-7. Target Interface Encodings** 

| TRGT  | Target Interface          | TRGT  | Target Interface |
|-------|---------------------------|-------|------------------|
| 00000 | Reserved                  | 10000 | Reserved         |
| 00001 | PCI Express 2             | 10001 | Reserved         |
| 00010 | PCI Express 1             | 10010 | Reserved         |
| 00011 | Reserved                  | 10011 | Reserved         |
| 00100 | Enhanced local bus (eLBC) | 10100 | Reserved         |
| 00101 | Reserved                  | 10101 | Reserved         |
| 00110 | Reserved                  | 10110 | Reserved         |
| 00111 | Reserved                  | 10111 | Reserved         |
| 01000 | Reserved                  | 11000 | Reserved         |
| 01001 | Reserved                  | 11001 | Reserved         |
| 01010 | Reserved                  | 11010 | Reserved         |
| 01011 | Reserved                  | 11011 | Reserved         |
| 01100 | Reserved                  | 11100 | Reserved         |
| 01101 | Reserved                  | 11101 | Reserved         |
| 01110 | Reserved                  | 11110 | Reserved         |
| 01111 | DDR memory controller     | 11111 | Reserved         |

Address: 0h base + C10h offset + (32d  $\times$  i), where i=0d to 11d



LAW\_LAWARn field descriptions

| Field    | Description                                                                                                                                                                                                                                                    |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EN  | <ul> <li>Enabled</li> <li>The local access window n (and all other LAWARn and LAWBARn fields) are disabled.</li> <li>The local access window n is enabled and other LAWARn and LAWBARn fields combine to identify an address range for this window.</li> </ul> |
| 1–6<br>- | This field is reserved. Reserved                                                                                                                                                                                                                               |

### LAW\_LAWARn field descriptions (continued)

| Field         |                                                                                                    | Description                                                                                                        |
|---------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| 7–11<br>TRGT  |                                                                                                    | et interface when a transaction hits in the address range defined by this window. The GT are defined in Table 2-7. |
| 12–25<br>-    | This field is reser<br>Reserved                                                                    | ved.                                                                                                               |
| 26–31<br>SIZE | Identifies the size Example settings  000000-001010  001011  001100  001101  100010  100011-111111 | Reserved 4 Kbytes 8 Kbytes 16 Kbytes 32 Gbytes                                                                     |

## 2.5 Address translation and mapping units

To facilitate flexibility in defining the address maps for external interfaces such as PCI Express, the device provides address translation and mapping units (ATMUs).

The following types of translation and mapping operations are performed by the ATMUs:

- Translating the local 36-bit address to an external address space
- Translating external addresses to the local 36-bit address space
- Assigning attributes to transactions
- Mapping a local address to a target interface

Outbound address translation and mapping refers to the translation of addresses from the local 36-bit address space to the external address space and attributes of a particular I/O interface.

Inbound address translation and mapping refers to the translation of an address from the external address space of an I/O interface to the local address space understood by the internal interfaces of this device. It also refers to the mapping of transactions to a particular target interface and the assignment of transaction attributes. Note that in mapping the transaction to the target interface, an inbound ATMU window performs a function similar to the local access windows. The target mappings created by an inbound ATMU must be consistent with those of the LAWs. That is, if an inbound ATMU maps a transaction to a given local address and a given target, a LAW must also map that same local address to the same target.

### 2.5.1 Address translation

All of the configuration registers that define an ATMU window's translation and mapping functions follow the same general register format, summarized in the table below.

 Register
 Function

 Translation address (TAR)
 High-order address bits defining location of the window in the target address space

 Base address (BAR)
 High-order address bits defining location of the window in the initiator address space

 Window attributes (WAR)
 Window enable, window size, target interface, and transaction attributes

Table 2-43. Format of ATMU window definitions

The size of the windows must be a power-of-two. To perform a translation or mapping function, the address of the transaction is compared with the base address register of each window. The number of bits used in the comparison is dictated by each window's size attribute. When an address hits a window, if address translation is being performed, the new translated address is created by concatenating the window offset to the translation address. Again, the windows size attribute dictates how many bits are translated.

### 2.5.2 Outbound ATMUs

If the target mapping performed by the local access windows directs the transaction to one of the external interfaces (as an outbound read or write), the transaction is then mapped into that interface's external address space by outbound ATMUs associated with the external interface.

The outbound ATMUs perform the mapping from the local 36-bit address space to the address space of PCI Express, which may be much larger than the local space. The outbound ATMUs also map attributes such as transaction type and priority level.

The PCI Express controller has four outbound ATMU windows plus a default window. If a transaction's address does not hit any of the four outbound ATMU windows, the translation attributes defined by the default window are used. The default window is always enabled. The PCI Express outbound ATMUs include extended translation address registers so that up to 64 bits of external address space can be supported. See PCI Express outbound ATMUs for a detailed description of the PCI Express outbound ATMU windows.

Address translation and mapping units

### 2.5.3 Inbound ATMUs

The inbound ATMUs perform the address translation from external address spaces to the local address space, attach attributes and transaction types to the transaction, and also map the transaction to its target interface.

The PCI Express controller has three general inbound ATMU windows plus a default. See PCI Express inbound ATMUs for a detailed description of the PCI-Express inbound ATMU windows.

## 2.5.3.1 Illegal interaction between inbound ATMUs and LAWs

Since both local access windows and inbound ATMUs map transactions to a target interface, it is essential that they not contradict one another.

For example, it is considered a programming error to have an inbound ATMU map a transaction to the DDR memory controller (target interface 0b0\_1111) if the resulting translated local address is mapped to the PCI Express interface (target interface 0b0\_000) by a local access window. Such programming errors may result in unpredictable system deadlocks.

# **Chapter 3 Signal Descriptions**

This chapter describes the external signals.

### 3.1 General overview

This chapter describes the external signals.

It is organized into the following sections:

- Overview of signals and cross-references for signals that serve multiple functions, including two lists: one by functional block and one alphabetical
- List of reset configuration signals
- List of output signal states at reset

### NOTE

A bar over a signal name indicates that the signal is active low, such as IRQ\_OUT\_B (interrupt output). Active-low signals are referred to as asserted (active) when they are low and negated when they are high. Signals that are not active low, such as IRQ (interrupt input), are referred to as asserted when they are high and negated when they are low.

Internal signals are shown throughout this document as lower case and in italics. For example, *sys\_logic\_clk* is an internal signal. These are discussed only as necessary for understanding the external functionality of the device.

## 3.2 Signals overview

The signals are grouped as follows:

### Signals overview

- DDR memory interface signals
- SerDes/PCI Express/SGMII interface signals
- Enhanced three-speed Ethernet Controller (eTSEC) interface signals
- Enhanced local bus interface signals
- eSDHC interface signals
- SPI interface signals
- USB interface signals
- DMA interface signals
- PIC interface signals
- DUART interface signals
- I<sup>2</sup>C interface signals
- QUICC Engine block interface signals
- System control, power management, and debug signals
- Test, JTAG, configuration, and clock signals

The figures below illustrate the external signals of the device, showing how the signals are grouped. Refer to the *P1021 QorIQ Integrated Processor Hardware Specifications* for a pinout diagram showing pin numbers and a listing of all the electrical and mechanical specifications. Note that these figures show multiplexed signals multiple times.



Figure 3-1. P1021 signal groupings (1/3)

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013



Figure 3-2. P1021 signal groupings (2/3) (continued)

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013



Figure 3-3. P1021 signal groupings (3/3) (continued)

### Signals overview

Note that individual chapters of this document provide details for each signal, describing each signal's behavior when the signal is asserted or negated and when the signal is an input or an output.

The following table provide summary of signals grouped by function. This table details the signal name, interface, alternate functions, number of signals, and whether the signal is an input, output, or bidirectional. The direction of the multiplexed signals applies for the primary signal function listed in the left-most column of the table for that row (and does not apply for the state of the reset configuration signals).

Table 3-1. Signal reference by functional block

| Name                      | Description                                    | Alternate Function(s) | No. of<br>Signals | I/O |
|---------------------------|------------------------------------------------|-----------------------|-------------------|-----|
| DDR Controller (See DDR   | external signal descriptions for more details) | •                     | •                 | •   |
| MDQ[0:31]                 | DDR data                                       | -                     | 32                | I/O |
| MECC[0:7]                 | DDR error correcting code                      | -                     | 8                 | I/O |
| MAPAR_ERR_B               | Address parity error                           | -                     | 1                 | I   |
| MAPAR_OUT                 | Address parity out                             | -                     | 1                 | 0   |
| MDM[0:3], MDM[8]          | DDR data mask                                  | -                     | 5                 | 0   |
| MDQS[0:3], MDQS8          | DDR data strobe                                | -                     | 5                 | I/O |
| MDQS_B[0:3], MDQS8_B      | DDR data strobe (complement)                   | -                     | 5                 | I/O |
| MBA[0:2]                  | DDR bank select                                | -                     | 3                 | 0   |
| MA[0:15]                  | DDR address                                    | -                     | 16                | 0   |
| MWE_B                     | DDR write enable                               | -                     | 1                 | 0   |
| MRAS_B                    | DDR row address strobe                         | -                     | 1                 | 0   |
| MCAS_B                    | DDR column address strobe                      | -                     | 1                 | 0   |
| MCS_B[0:1]                | DDR chip select                                | -                     | 2                 | 0   |
| MCKE[0:1]                 | DDR clock enable                               | -                     | 2                 | 0   |
| MCK[0:3], MCK_B[0:3]      | DDR differential clocks (2 pairs/DIMM)         | -                     | 8                 | 0   |
| MODT[0:1]                 | DRAM on-die termination                        | -                     | 2                 | 0   |
| MDIC[0:1]                 | Driver impedance calibration                   | -                     | 2                 | I/O |
| SerDes (See PCI Express s | ignal descriptions for more details)           |                       |                   | •   |
| SD_TX[3:0]                | Transmit data                                  | -                     | 4                 | 0   |
| SD_TX_B[3:0]              | Transmit data (complement)                     | -                     | 4                 | 0   |
| SD_RX[3:0]                | Receive data                                   | -                     | 4                 | I   |
| SD_RX_B[3:0]              | Receive data (complement)                      | -                     | 4                 | I   |
| SD_REF_CLK                | PLL reference clock                            | -                     | 1                 | I   |
| SD_REF_CLK_B              | PLL reference clock (complement)               | -                     | 1                 | I   |
| IEEE 1588 (See eTSEC ext  | ernal signals description for more details)    | •                     | '                 |     |
| TSEC_1588_ CLK_IN         | 1588 clock-in                                  | -                     | 1                 | I   |
| TSEC_1588_ TRIG_IN1       | 1588 trigger-in 1                              | -                     | 1                 | I   |
| TSEC_1588_ TRIG_IN2       | 1588 trigger-in 2                              | -                     | 1                 | I   |

Table 3-1. Signal reference by functional block (continued)

| Name                       | Description                               | Alternate Function(s)   | No. of<br>Signals | I/O |
|----------------------------|-------------------------------------------|-------------------------|-------------------|-----|
| TSEC_1588_<br>ALARM_OUT1   | 1588 timer alarm-out 1                    | cfg_srds_refclk         | 1                 | 0   |
| TSEC_1588_<br>ALARM_OUT2   | 1588 timer alarm-out 2                    | cfg_sgmii3              | 1                 | 0   |
| TSEC_1588_ CLK_OUT         | 1588 clock-out                            | cfg_ddr_pll0            | 1                 | 0   |
| TSEC_1588_<br>PULSE_OUT1   | 1588 timer pulse-out 1                    | cfg_ddr_pll1            | 1                 | 0   |
| TSEC_1588_<br>PULSE_OUT2   | 1588 timer pulse-out 2                    | cfg_ddr_pll2            | 1                 | 0   |
| Ethernet Controller MI (Se | e eTSEC external signals description for  | more details)           |                   | !   |
| EC_GTX_CLK125              | Gigabit reference clock                   | -                       | 1                 | I   |
| EC_MDC                     | Ethernet management data clock            | cfg_tsec_reduce         | 1                 | 0   |
| EC_MDIO                    | Ethernet management data in/out           | -                       | 1                 | I/O |
| eTSEC Controller 1 (See    | TSEC external signals description for mo  | ore details)            |                   |     |
| TSEC1_TXD[3:1]             | eTSEC1 transmit data 3-1                  | cfg_io_ports[0:2]       | 3                 | 0   |
| TSEC1_TXD0                 | eTSEC1 transmit data 0                    | cfg_tsec1_prtcl0        | 1                 | 0   |
| TSEC1_TX_EN                | eTSEC1 transmit enable                    | -                       | 1                 | 0   |
| TSEC1_TX_ER                | eTSEC1 transmit error                     | cfg_rom_loc3            | 1                 | 0   |
| TSEC1_TX_CLK               | eTSEC1 transmit clock in                  | TSEC1_GTX_CLK125        | 1                 | I   |
| TSEC1_CRS                  | eTSEC1 carrier sense                      | TSEC3_RX_DV             | 1                 | I/O |
| TSEC1_COL                  | eTSEC1 collision detect                   | TSEC3_RX_CLK            | 1                 | I   |
| TSEC1_RXD[3:0]             | eTSEC1 receive data 3-0                   | -                       | 4                 | I   |
| TSEC1_RX_DV                | eTSEC1 receive data valid                 | -                       | 1                 | I   |
| TSEC1_RX_ER                | eTSEC1 receiver error                     | -                       | 1                 | I   |
| TSEC1_RX_CLK               | eTSEC1 receive clock                      | -                       | 1                 | I   |
| TSEC1_GTX_CLK125           | eTSEC1 Gigabit reference clock            | TSEC1_TX_CLK            | 1                 | I   |
| TSEC1_GTX_CLK              | eTSEC1 transmit clock out                 | -                       | 1                 | 0   |
| eTSEC Controller 3 (See    | TSEC external signals description for mo  | ore details)            | ļ.                |     |
| TSEC3_TXD3                 | eTSEC3 transmit data 3                    | cfg_tsec1_prtcl1        | 1                 | 0   |
| TSEC3_TXD[2:0]             | eTSEC3 transmit data 2-0                  | cfg_rom_loc[0:2]        | 3                 | 0   |
| TSEC3_TX_EN                | eTSEC3 transmit enable                    | cfg_sdhc_cd_pol_sel     | 1                 | 0   |
| TSEC3_RX_ER                | eTSEC3 receive error                      | -                       | 1                 | I/O |
| TSEC3_TX_CLK               | eTSEC3 transmit clock in                  | -                       | 1                 | I   |
| TSEC3_GTX_CLK              | eTSEC3 transmit clock out                 | -                       | 1                 | 0   |
| TSEC3_RXD[3:0]             | eTSEC3 receive data 3-0                   | -                       | 4                 | I   |
| TSEC3_RX_DV                | eTSEC3 receive data valid                 | TSEC1_CRS               | 1                 | I/O |
| TSEC3_RX_CLK               | eTSEC3 receive clock                      | TSEC1_COL               | 1                 | I   |
| Enhanced Local Bus Cont    | troller (See eLBC external signal descrip | tions for more details) |                   | 1   |
| LAD[0:7]                   | Local bus address/data 0-7                | cfg_gpinput[0:7]        | 8                 | I/O |
| LAD8                       | Local bus address/data 8                  | CE_PA0/ cfg_gpinput8    | 1                 | I/O |

Table 3-1. Signal reference by functional block (continued)

| Name                            | Description                                                                | Alternate Function(s)          | No. of<br>Signals | I/O |
|---------------------------------|----------------------------------------------------------------------------|--------------------------------|-------------------|-----|
| LAD9                            | Local bus address/data 9                                                   | cfg_gpinput9                   | 1                 | I/O |
| LAD10                           | Local bus address/data 10                                                  | cfg_gpinput10                  | 1                 | I/O |
| LAD11                           | Local bus address/data 11                                                  | cfg_gpinput11                  | 1                 | I/O |
| LAD12                           | Local bus address/data 12                                                  | cfg_gpinput12                  | 1                 | I/O |
| LAD13                           | Local bus address/data 13                                                  | cfg_gpinput13                  | 1                 | I/O |
| LAD14                           | Local bus address/data 14                                                  | cfg_gpinput14                  | 1                 | I/O |
| LAD15                           | Local bus address/data 15                                                  | cfg_gpinput15                  | 1                 | I/O |
| LDP[0:1]                        | Local bus data parity                                                      | CE_PA[11:12]                   | 2                 | I/O |
| LA16                            | Local bus burst address 16                                                 | CE_PA4/ cfg_cpu1_boot          | 1                 | I/O |
| LA17                            | Local bus burst address 17                                                 | CE_PA5                         | 1                 | I/O |
| LA[18:19]                       | Local bus burst address 18-19                                              | CE_PA[6:7]/ cfg_host_agt[1:2]  | 2                 | I/O |
| LA[20:22]                       | Local bus burst address 20-22                                              | cfg_eng_use[0:2]/CE_PA[8:10]   | 3                 | I/O |
| LA23                            | Local bus burst address 23                                                 | CE_PA17/ cfg_plat_speed        | 1                 | I/O |
| LA24                            | Local bus burst address 24                                                 | CE_PA18/ cfg_core0_speed       | 1                 | I/O |
| LA25                            | Local bus burst address 25                                                 | CE_PA19/ cfg_core1_speed       | 1                 | I/O |
| LA26                            | Local bus burst address 26                                                 | CE_PA20/ cfg_ddr_speed         | 1                 | I/O |
| LA27                            | Local bus burst address 27                                                 | CE_PA21/ cfg_cpu0_boot         | 1                 | I/O |
| LA28                            | Local bus burst address 28                                                 | CE_PA13/ cfg_sys_speed         | 1                 | I/O |
| LA[29:30]                       | Local bus port address 29-30                                               | CE_PA[25:26]/ cfg_sys_pll[0:1] | 2                 | I/O |
| LA31                            | Local bus port address 31                                                  | CE_PA30/ cfg_sys_pll2          | 1                 | I/O |
| LCS_B[0:3]                      | Local bus chip select 0-3                                                  | -                              | 4                 | 0   |
| LCS_B[4:6]                      | Local bus chip select 4-6                                                  | CE_PA[22:24]                   | 3                 | 0   |
| LCS7_B                          | Local bus chip select 7                                                    | CE_PA27                        | 1                 | 0   |
| LWE0_B/LFWE_B/LBS0_B            | Local bus write enable 0 / write enable / byte lane select 1               | cfg_core1_pll0                 | 1                 | 0   |
| LWE1_B/LBS1_B                   | Local bus write enable1 / bye lane select 1                                | CE_PB9/ cfg_host_agt0          | 1                 | I/O |
| LBCTL                           | Local bus data buffer control                                              | CE_PB20/ cfg_core0_pll0        | 1                 | I/O |
| LALE                            | Local bus address latch enable                                             | cfg_core0_pll1                 | 1                 | 0   |
| LGPL0/ LFCLE                    | Local bus UPM general purpose line 0 / flash command latch enable          | CE_PA1                         | 1                 | I/O |
| LGPL1/ LFALE                    | Local bus GP line 1 / flash address latch enable                           | CE_PA2                         | 1                 | I/O |
| LGPL2/LOE_B/LFRE_B              | Local bus GP line 2 / output enable / flash read enable                    | cfg_core0_pll2                 | 1                 | 0   |
| LGPL3/LFWP_B                    | Local bus GP line 3 / flash write protect                                  | CE_PA3/ cfg_boot_seq0          | 1                 | I/O |
| LGPL4/LGTA_B/LFRB_B/<br>LUPWAIT | Local bus GP line 4 / transaction<br>termination / flash ready-busy / wait | -                              | 1                 | I/O |
| LGPL5                           | Local bus GP line 5 address                                                | CE_PA14/ cfg_boot_seq1         | 1                 | I/O |
| LCLK0                           | Local bus clock 0                                                          | CE_PA28                        | 1                 | I/O |
| LCLK1                           | Local bus clock 1                                                          | CE_PA16                        | 1                 | I/O |
|                                 | L                                                                          | +                              |                   | -   |

Table 3-1. Signal reference by functional block (continued)

| Name                    | Description                                   | Alternate Function(s)    | No. of<br>Signals | I/O |
|-------------------------|-----------------------------------------------|--------------------------|-------------------|-----|
| eSDHC (See eSDHC ex     | ternal signal description for more details)   | •                        | •                 |     |
| SDHC_CMD                | CMD line connect to card                      | -                        | 1                 | I/O |
| SDHC_DAT[0:3]           | Data line 0-3                                 | -                        | 4                 | I/O |
| SDHC_DAT[4:7]           | Data line 4-7                                 | SPI_CS_B[0:3]            | 4                 | I/O |
| SDHC_CD_B               | eSDHC card detection                          | CE_PB12                  | 1                 | I/O |
| SDHC_WP                 | eSDHC card write protect                      | CE_PB13                  | 1                 | I/O |
| SDHC_CLK                | Clock for MMC/SD card                         | -                        | 1                 | 0   |
| eSPI (See eSDHC exter   | rnal signal description for more details)     |                          |                   |     |
| SPI_MOSI                | SPI master-out slave-in                       | -                        | 1                 | I/O |
| SPI_MISO                | SPI master-in slave-out                       | -                        | 1                 | ı   |
| SPI_CLK                 | SPI clock                                     | -                        | 1                 | 0   |
| SPI_CS_B[0:3]           | SPI slave select 0-3                          | SDHC_DAT[4:7]            | 4                 | I/O |
| USB (See USB external   | signals for more details)                     |                          | I                 |     |
| USB_D[7:0]              | Data bus                                      | -                        | 8                 | I/O |
| USB_NXT                 | Next data                                     | -                        | 1                 | ı   |
| USB_DIR                 | Direction of data bus                         | -                        | 1                 | ı   |
| USB_STP                 | End of a transfer on the bus                  | -                        | 1                 | 0   |
| USB_PCTL0               | Port control 0                                | CE_PB8                   | 1                 | I/O |
| USB_PCTL1               | Port control1                                 | CE_PA15                  | 1                 | I/O |
| USB_PWRFAULT            | USB VBus power fault                          | -                        | 1                 | ı   |
| USB_CLK                 | USB PHY clock                                 | -                        | 1                 | ı   |
| DMA (See DMA externa    | al signal description for more details)       |                          |                   |     |
| DMA_DREQ0_B             | DMA request 0                                 | -                        | 1                 | I   |
| DMA_DACK0_B             | DMA acknowledge 0                             | -                        | 1                 | 0   |
| DMA_DDONE0_B            | DMA done 0                                    | -                        | 1                 | 0   |
| PIC (See PIC external s | ignal descriptions and GPIO signal descrip    | otions for more details) |                   |     |
| MCP_B[0:1]              | Machine check processor                       | -                        | 2                 | I   |
| UDE_B[0:1]              | Unconditional debug event                     | -                        | 2                 | ı   |
| IRQ_OUT_B               | Interrupt output                              | -                        | 1                 | 0   |
| IRQ[0:5]                | External interrupt 0-5                        | -                        | 6                 | ı   |
| IRQ6                    | External interrupt 6                          | CE_PB10                  | 1                 | I/O |
| QUICC Engine (See GF    | PIO signal descriptions for more details)     |                          |                   |     |
| DUART (See DUART e      | xternal signal descriptions for more details) | )                        |                   |     |
| UART_SOUT0              | UART0 serial data out                         | cfg_eng_use[3]           | 1                 | 0   |
| UART_SOUT1              | UART1 serial data out                         | CE_PB17/ cfg_core1_pll1  | 1                 | I/O |
| UART_SIN0               | UART0 serial data in                          | -                        | 1                 | I   |
| UART_SIN1               | UART1 serial data in                          | CE_PB16                  | 1                 | I/O |
| UART_CTS0_B             | UART0 clear to send                           | -                        | 1                 | 1   |
| UART_CTS1_B             | UART1 clear to send                           | CE_PB14                  | 1                 | I/O |

Table 3-1. Signal reference by functional block (continued)

| Name                                      | Description                               | Alternate Function(s)           | No. of<br>Signals | I/O |
|-------------------------------------------|-------------------------------------------|---------------------------------|-------------------|-----|
| UART_RTS0_B                               | UART0 ready to send                       | cfg_tsec3_prtcl0                | 1                 | 0   |
| UART_RTS1_B                               | UART1 ready to send                       | CE_PB15/ cfg_tsec3_prtcl1       | 1                 | 0   |
| I2C (See I <sup>2</sup> C external signal | al descriptions for more details)         |                                 |                   |     |
| IIC1_SDA                                  | I <sup>2</sup> C1 serial data             | -                               | 1                 | I/O |
| IIC1_SCL                                  | I <sup>2</sup> C1 serial clock            | -                               | 1                 | I/O |
| IIC2_SDA                                  | I <sup>2</sup> C2 serial data             | CE_PB21                         | 1                 | I/O |
| IIC2_SCL                                  | I <sup>2</sup> C2 serial clock            | CE_PB22                         | 1                 | I/O |
| TDM (See TDM external s                   | ignals descriptions for more details)     |                                 |                   | -   |
| QUICC Engine (See Table                   | e 3-7, Table 3-8, Table 3-9 for more deta | ils)                            |                   |     |
| CE_PA0                                    | QUICC Engine parallel port A              | LAD8/ cfg_gpinput8              | 1                 | I/O |
| CE_PA1                                    | QUICC Engine parallel port A              | LGPL0/LFCLE                     | 1                 | I/O |
| CE_PA2                                    | QUICC Engine parallel port A              | LGPL1/ LFALE                    | 1                 | I/O |
| CE_PA3                                    | QUICC Engine parallel port A              | LGPL3/LFWP_B/<br>cfg_boot_seq0  | 1                 | I/O |
| CE_PA4                                    | QUICC Engine parallel port A              | LA16/ cfg_cpu1_boot             | 1                 | I/O |
| CE_PA5                                    | QUICC Engine parallel port A              | LA17                            | 1                 | I/O |
| CE_PA[6:7]                                | QUICC Engine parallel port A              | LA[18:19]/ cfg_host_agt[1:2]    | 2                 | I/O |
| CE_PA[8:10]                               | QUICC Engine parallel port A              | LA[20:22]/ cfg_eng_use[0:2]     | 3                 | I/O |
| CE_PA[11:12]                              | QUICC Engine parallel port A              | LDP[0:1]                        | 2                 | I/O |
| CE_PA13                                   | QUICC Engine parallel port A              | LA28/ cfg_sys_speed             | 1                 | I/O |
| CE_PA14                                   | QUICC Engine parallel port A              | LGPL5/ cfg_boot_seq1            | 1                 | I/O |
| CE_PA15                                   | QUICC Engine parallel port A              | USB_PCTL1                       | 1                 | I/O |
| CE_PA16                                   | QUICC Engine parallel port A              | LCLK1                           | 1                 | I/O |
| CE_PA17                                   | QUICC Engine parallel port A              | LA23/ cfg_plat_speed            | 1                 | I/O |
| CE_PA18                                   | QUICC Engine parallel port A              | LA24/ cfg_core0_speed           | 1                 | I/O |
| CE_PA19                                   | QUICC Engine parallel port A              | LA25/ cfg_core1_speed           | 1                 | I/O |
| CE_PA20                                   | QUICC Engine parallel port A              | LA26/ cfg_ddr_speed             | 1                 | I/O |
| CE_PA21                                   | QUICC Engine parallel port A              | LA27/ cfg_cpu0_boot             | 1                 | I/O |
| CE_PA[22:24]                              | QUICC Engine parallel port A              | LCS_B[4:6]                      | 1                 | 0   |
| CE_PA[25:26]                              | QUICC Engine parallel port A              | LA[29:30]/ cfg_sys_pll[0:1]     | 2                 | I/O |
| CE_PA27                                   | QUICC Engine parallel port A              | LCS7_B                          | 3                 | 0   |
| CE_PA28                                   | QUICC Engine parallel port A              | LCLK0                           | 1                 | I/O |
| CE_PA29                                   | QUICC Engine parallel port A              | cfg_ddr_debug                   | 1                 | I/O |
| CE_PA30                                   | QUICC Engine parallel port A              | LA31/ cfg_sys_pll2              | 1                 | I/O |
| CE_PA31                                   | QUICC Engine parallel port A              | -                               | 1                 | I/O |
| CE_PB[0:7]                                | QUICC Engine parallel port B              |                                 | 8                 | I/O |
| CE_PB8                                    | QUICC Engine parallel port B              | USB_PCTL0                       | 1                 | I/O |
| CE_PB9                                    | QUICC Engine parallel port B              | LWE1_B/LBS1_B/<br>cfg_host_agt0 | 1                 | I/O |

Table 3-1. Signal reference by functional block (continued)

| Name                   | Description                                 | Alternate Function(s)                       | No. of<br>Signals | I/O |
|------------------------|---------------------------------------------|---------------------------------------------|-------------------|-----|
| CE_PB10                | QUICC Engine parallel port B                | IRQ6                                        | 1                 | I/O |
| CE_PB11                | QUICC Engine parallel port B                | -                                           | 1                 | I/O |
| CE_PB12                | QUICC Engine parallel port B                | SDHC_CD_B                                   | 1                 | I/O |
| CE_PB13                | QUICC Engine parallel port B                | SDHC_WP                                     | 1                 | I/O |
| CE_PB14                | QUICC Engine parallel port B                | UART_CTS1_B                                 | 1                 | I/O |
| CE_PB15                | QUICC Engine parallel port B                | UART_RTS1_B/<br>cfg_tsec3_prtcl1            | 1                 | 0   |
| CE_PB16                | QUICC Engine parallel port B                | UART_SIN1                                   | 1                 | I/O |
| CE_PB17                | QUICC Engine parallel port B                | UART_SOUT1/ cfg_core1_pll1                  | 1                 | I/O |
| CE_PB18                | QUICC Engine parallel port B                | -                                           | 1                 |     |
| CE_PB19                | QUICC Engine parallel port B                | cfg_mem_debug                               | 1                 | I/O |
| CE_PB20                | QUICC Engine parallel port B                | LBCTL/ cfg_core0_pll0                       | 1                 | I/O |
| CE_PB21                | QUICC Engine parallel port B                | IIC2_SDA                                    | 1                 | I/O |
| CE_PB22                | QUICC Engine parallel port B                | IIC2_SCL                                    | 1                 | I/O |
| CE_PB23                | QUICC Engine parallel port B                | MSRCID0/ cfg_elbc_ecc                       | 1                 | I/O |
| CE_PB24                | QUICC Engine parallel port B                | MSRCID1                                     | 1                 | I/O |
| CE_PB25                | QUICC Engine parallel port B                | MSRCID2                                     | 1                 | I/O |
| CE_PB26                | QUICC Engine parallel port B                | MSRCID3                                     | 1                 | I/O |
| CE_PB27                | QUICC Engine parallel port B                | MSRCID4/ cfg_eng_use[6]                     | 1                 | I/O |
| CE_PB28                | QUICC Engine parallel port B                | MDVAL                                       | 1                 | I/O |
| CE_PB29                | QUICC Engine parallel port B                | -                                           | 1                 | I/O |
| CE_PB30                | QUICC Engine parallel port B                | -                                           | 1                 | I/O |
| CE_PB31                | QUICC Engine parallel port B                | -                                           | 1                 | I/O |
| CE_PC0                 | QUICC Engine parallel port C                | -                                           | 1                 | I/O |
| System Control (See Re | eset external signal descriptions and Globa | I utilities external signal description for | more details      | 3)  |
| HRESET_B               | Hard reset                                  | -                                           | 1                 | I   |
| HRESET_REQ_B           | Hard reset request                          | -                                           | 1                 | 0   |
| SRESET_B               | Soft reset                                  | -                                           | 1                 | ı   |
| CKSTP_IN_B[0:1]        | Checkstop in                                | -                                           | 2                 | I   |
| CKSTP_OUT_B[0:1]       | Checkstop out                               | -                                           | 2                 | 0   |
| Debug (See Debug exter | rnal signal description for more details)   | ,                                           |                   | -1  |
| TRIG_IN                | Watchpoint trigger in                       | -                                           | 1                 | I   |
| TRIG_OUT               | Watchpoint trigger out                      | -                                           | 1                 | 0   |
| READY_P1               | Processor 1 ready                           | cfg_core1_pll2                              | 1                 | 0   |
| MSRCID0                | Memory debug source ID 0                    | CE_PB23/ cfg_elbc_ecc                       | 1                 | I/O |
| MSRCID1                | Memory debug source ID 1                    | CE_PB24                                     | 1                 | I/O |
| MSRCID2                | Memory debug source ID 2                    | CE_PB25                                     | 1                 | I/O |
| MSRCID3                | Memory debug source ID 3                    | CE_PB26                                     | 1                 | I/O |
| MSRCID4                | Memory debug source ID 4                    | CE_PB27/ cfg_eng_use[6]                     | 1                 | I/O |

Table 3-1. Signal reference by functional block (continued)

| Name                       | Description                                        | Alternate Function(s) | No. of<br>Signals | I/O |
|----------------------------|----------------------------------------------------|-----------------------|-------------------|-----|
| MDVAL                      | Memory debug data valid                            | CE_PB28               | 1                 | I/O |
| CFG_MEM_ DEBUG             | Memory debug configuration                         | CE_PB19               | 1                 | I/O |
| CFG_DDR_ DEBUG             | DDR debug configuration                            | CE_PA29               | 1                 | I/O |
| CFG_IO_PORTS3              | I/O port configuration                             | -                     | 1                 | I   |
| CFG_DRAM_TYPE              | DDR DRAM type configuration                        | -                     | 1                 | 0   |
| Power Management (See      | Global utilities external signal description for m | ore details)          |                   | •   |
| ASLEEP                     | Asleep                                             | -                     | 1                 | 0   |
| CLK_OUT                    | Clock out                                          | -                     | 1                 | 0   |
| Clocking (See Reset extern | al signal descriptions for more details)           |                       |                   | •   |
| SYSCLK                     | System clock                                       | -                     | 1                 | I   |
| RTC                        | Real time clock                                    | -                     | 1                 | I   |
| DDRCLK                     | DDR clock                                          | -                     | 1                 | I   |
| Test and JTAG (See Debug   | external signal description for more details)      |                       |                   | •   |
| SCAN_MODE_B                | Test select                                        | -                     | 1                 | I   |
| TEST_SEL_B                 | Test select                                        | -                     | 1                 | I   |
| TCK                        | Test clock                                         | -                     | 1                 | I   |
| TDI                        | Test data in                                       | -                     | 1                 | I   |
| TDO                        | Test data out                                      | -                     | 1                 | 0   |
| TMS                        | Test mode select                                   | -                     | 1                 | I   |
| TRST_B                     | Test reset                                         | -                     | 1                 | I   |
| IO VSEL (See Reset externa | al signal descriptions for more details)           |                       |                   |     |
| LVDD_VSEL                  | LVDD voltage select                                | -                     | 1                 | I   |
| BVDD_VSEL[0:1]             | BVDD voltage select                                | -                     | 2                 | I   |
| CVDD_VSEL[0:1]             | CVDD voltage select                                | -                     | 2                 | I   |
| Analog (See eTSEC externa  | al signals description for more details)           |                       | •                 |     |
| SD_PLL_TPD                 | PLL test point digital                             | -                     | 1                 | 0   |
| SD_PLL_TPA                 | PLL test point analog                              | -                     | 1                 | 0   |
| SD_IMP_CAL_TX              | Transmitter impedance calibration                  | -                     | 1                 | I   |
| SD_IMP_CAL_RX              | Receiver impedance calibration                     | -                     | 1                 | I   |

## 3.3 Configuration signals sampled at reset

The signals that serve alternate functions as configuration input signals during system reset are summarized in the table below.

The detailed interpretation of their voltage levels during reset is described in the "Reset" chapter.

Note that throughout this document, the reset configuration signals are described as being sampled at the negation of HRESET\_B. However, there is a setup and hold time for these signals relative to the rising edge of HRESET\_B, as described in the *P1021 QorIQ Integrated Processor Hardware Specifications*. Note that the PLL configuration signals have different setup and hold time requirements than the other reset configuration signals.

The reset configuration signals are multiplexed with other functional signals. The values on these signals during reset are interpreted to be logic one or zero, regardless of whether the functional signal name is defined as active-low. Most of the reset configuration signals have internal pull-up resistors so that if the signals are not driven, the default value is high (a one), as shown in the table. Some signals do not have pull-up resistors and must be driven high or low during the reset period. For details about all the signals that require external pull-up resistors, see the *P1021 QorIQ Integrated Processor Hardware Specifications*.

Note that the multiplexing of various signals on the device is controlled by the PMUXCR register described in the "Global Utilities" chapter.

**Functional Signal Name Reset Configuration Name Functional Interface** Default Debug READY\_P1 cfg\_core1\_pll2 Must be driven MSRCID0 cfg\_elbc\_ecc 1 MSRCID4 cfg\_eng\_use6 DUART UART\_SOUT1 cfg\_core1\_pll1 Must be driven UART\_RTS0\_B cfg\_tsec3\_prtcl0 UART\_RTS1\_B cfg\_tsec3\_prtcl1 1 UART\_SOUT0 cfg\_eng\_use3 el BC LGPL3/LFWP\_B cfg\_boot\_seq0 LGPL5 cfg\_boot\_seq1 **LBCTL** cfg\_core0\_pll0 Must be driven LALE cfg\_core0\_pll1 Must be driven LGPL2/LOE\_B/LFRE\_B cfg\_core0\_pll2 Must be driven LA16 cfg\_cpu1\_boot 11 LA[18:19] cfg\_host\_agt[1:2] LA23 cfg\_plat\_speed LA24 cfg\_core0\_speed 1 LA25 cfg\_core1\_speed 1 LA26 cfg\_ddr\_speed 1 LA27 cfg\_cpu0\_boot LA28 cfg\_sys\_speed LA[29:31] cfg\_sys\_pll[0:2] Must be driven LAD[0:15] cfg\_gpinput[0:15] All ones

Table 3-2. Reset configuration signals

Table 3-2. Reset configuration signals (continued)

| Functional Interface | Functional Signal Name | Reset Configuration Name | Default        |
|----------------------|------------------------|--------------------------|----------------|
|                      | LWE0_B/LFWE_B/LBS0_B   | cfg_core1_pll0           | Must be driven |
|                      | LWE1_B/LBS1_B          | cfg_host_agt0            | 1              |
|                      | LA[20:22]              | cfg_eng_use[0:2]         | 111            |
| Ethernet Management  | EC_MDC                 | cfg_tsec_reduce          | 1              |
| IEEE 1588            | TSEC_1588_CLK_OUT      | cfg_ddr_pll0             | Must be driven |
|                      | TSEC_1588_PULSE_OUT1   | cfg_ddr_pll1             | Must be driven |
|                      | TSEC_1588_PULSE_OUT2   | cfg_ddr_pll2             | Must be driven |
|                      | TSEC_1588_ALARM_OUT1   | cfg_srds_refclk          | 1              |
|                      | TSEC_1588_ALARM_OUT2   | cfg_sgmii3               | 1              |
| eTSEC1               | TSEC1_TXD[3:1]         | cfg_io_ports[0:2]        | 111            |
|                      | TSEC1_TX_ER            | cfg_rom_loc3             | 1              |
|                      | TSEC1_TXD0             | cfg_tsec1_prtcl0         | 1              |
|                      | TSEC3_TXD3             | cfg_tsec1_prtcl1         | 1              |
|                      | TSEC3_TXD[2:0]         | cfg_rom_loc[0:2]         | 111            |
| eTSEC3               | TSEC3_TX_EN            | cfg_sdhc_cd_pol_sel      | 1              |
| Configuration-only   | CFG_MEM_DEBUG          | cfg_mem_debug            | 1              |
|                      | CFG_DDR_DEBUG          | cfg_ddr_debug            | 1              |
|                      | CFG_DRAM_TYPE          | cfg_dram_type            | 1              |
|                      | CFG_IO_PORTS3          | cfg_io_ports3            | 1              |

## 3.4 Output Signal States During Reset

When a system reset is recognized (HRESET\_B is asserted), the chip aborts all current internal and external transactions and releases all bidirectional I/O signals to a high-impedance state.

See Reset, Clocking, and Initialization for a complete description of the reset functionality.

During reset, the chip ignores most input signals (except for the reset configuration signals) and drives most of the output-only signals to an inactive state.

**Table 3-3. Output Signal States During Reset** 

| Interface      | Signal     | State During Reset |
|----------------|------------|--------------------|
| DDR Controller | MA[0:15]   | High-Z             |
| DDR Controller | MBA[0:2]   | High-Z             |
| DDR Controller | MCS_B[0:1] | High-Z             |

Table 3-3. Output Signal States During Reset (continued)

| Interface             | Signal                    | State During Reset |
|-----------------------|---------------------------|--------------------|
| DDR Controller        | MCKE[0:1]                 | Driven Low         |
| DDR Controller        | MCK[0:3]                  | Driven Low         |
| DDR Controller        | MCK_B[0:3]                | Driven High        |
| DDR Controller        | MODT[0:1]                 | Driven Low         |
| DDR Controller        | MDIC[0:1]                 | High-Z             |
| DDR Controller        | MDM[0:3], MDM[8]          | High-Z             |
| DDR Controller        | MDQ[0:31]                 | High-Z             |
| DDR Controller        | MDQS[0:3], MDQS[8]        | High-Z             |
| DDR Controller        | MDQS_B[0:3], MDQS_B[8]    | High-Z             |
| DDR Controller        | MECC[0:7]                 | High-Z             |
| DDR Controller        | MAPAR_OUT                 | High-Z             |
| DDR Controller        | MWE_B                     | High-Z             |
| DDR Controller        | MRAS_B                    | High-Z             |
| DDR Controller        | MCAS_B                    | High-Z             |
| eLBC                  | LA[16:31]                 | POR Weak Pullup    |
| eLBC                  | LAD[0:15]                 | POR Weak Pullup    |
| eLBC                  | LCLK[0:1]                 | Driven Low         |
| eLBC                  | LCS_B[0:7]                | Driven High        |
| eLBC                  | LDP[0:1]                  | High-Z             |
| eLBC                  | LWE_B[0:1]                | POR Weak Pullup    |
| eLBC                  | LBCTL                     | POR Weak Pullup    |
| eLBC                  | LALE                      | POR Weak Pullup    |
| eLBC                  | LGPL[0:1]                 | Driven High        |
| eLBC                  | LGPL[2:3]                 | POR Weak Pullup    |
| eLBC                  | LGPL[4]                   | High-Z             |
| eLBC                  | LGPL[5]                   | POR Weak Pullup    |
| SPI                   | SPI_MOSI                  | High-Z             |
| SPI                   | SPI_CLK                   | High-Z             |
| SPI                   | SPI_CS_B[0:3]             | Driven High        |
| DUART                 | UART_SOUT[0:1]            | POR Weak Pullup    |
| DUART                 | UART_RTS_B[0:1]           | POR Weak Pullup    |
| DMA                   | DMA_DACK0_B               | POR Weak Pullup    |
| DMA                   | DMA_DDONE0_B              | POR Weak Pullup    |
| IEEE 1588             | TSEC_1588_ ALARM_OUT[1:2] | POR Weak Pullup    |
| IEEE 1588             | TSEC_1588_ CLK_OUT        | POR Weak Pullup    |
| IEEE 1588             | TSEC_1588_ PULSE_OUT[1:2] | POR Weak Pullup    |
| Ethernet Management   | EC_MDC                    | POR Weak Pullup    |
| Ethernet Management   | EC_MDIO                   | High-Z             |
| Ethernet Controller 1 | TSEC1_TXD[3:0]            | POR Weak Pullup    |

**Table 3-3. Output Signal States During Reset (continued)** 

| Interface             | Signal           | State During Reset |
|-----------------------|------------------|--------------------|
| Ethernet Controller 1 | TSEC1_TX_EN      | Driven Low         |
| Ethernet Controller 1 | TSEC1_TX_ER      | POR Weak Pullup    |
| Ethernet Controller 1 | TSEC1_GTX_CLK    | Driven Low         |
| Ethernet Controller 3 | TSEC3_GTX_CLK    | High-Z             |
| Ethernet Controller 3 | TSEC3_TX_EN      | POR Weak Pullup    |
| l <sup>2</sup> C      | IIC1_SDA         | High-Z             |
| l <sup>2</sup> C      | IIC1_SCL         | High-Z             |
| l <sup>2</sup> C      | IIC2_SDA         | High-Z             |
| l <sup>2</sup> C      | IIC2_SCL         | High-Z             |
| eSDHC                 | SDHC_CMD         | High-Z             |
| eSDHC                 | SDHC_DAT[0:3]    | High-Z             |
| eSDHC                 | SDHC_CLK         | Driven Low         |
| PIC                   | IRQ_OUT_B        | High-Z             |
| USB                   | USB_STP          | Driven High        |
| USB                   | USB_D[7:0]       | High-Z             |
| QUICC Engine          | CE_PB[2]         | High-Z             |
| QUICC Engine          | CE_PB[3]         | High-Z             |
| QUICC Engine          | CE_PB[18]        | High-Z             |
| System Control        | HRESET_REQ_B     | POR Weak Pullup    |
| System Control        | CKSTP_OUT_B[0:1] | High-Z             |
| Debug                 | READY_P1         | POR Weak Pullup    |
| Debug                 | TRIG_OUT         | POR Weak Pullup    |
| Debug                 | MDVAL            | POR Weak Pullup    |
| Debug                 | MSRCID[0:4]      | POR Weak Pullup    |
| Debug                 | CFG_DRAM_TYPE    | POR Weak Pullup    |
| Debug                 | CFG_MEM_DEBUG    | POR Weak Pullup    |
| Debug                 | CFG_DDR_DEBUG    | POR Weak Pullup    |
| Power Management      | CLK_OUT          | High-Z             |
| Power Management      | ASLEEP           | POR Weak Pullup    |
| JTAG                  | TDO              | High-Z             |
|                       |                  |                    |

# 3.5 Parallel I/O ports

The QUICC Engine Block supports three general purpose I/O ports: ports A, B, and C.

Each pin in the I/O ports can be configured as a general-purpose I/O signal or as a dedicated peripheral interface signal. Each pin can be configured as open-drain (the pin can be configured in a wired-OR configuration on the board). While configured as open-drain, the pin drives a zero voltage but three-states when driving a high voltage.

Note that port pins do not have internal pull-up resistor. Due to the QUICC Engine Block's flexibility, many dedicated peripheral functions are multiplexed onto the ports. The functions are grouped to maximize the pins' usefulness in the greatest number of device applications.

# 3.5.1 QUICC engine block port block diagram

The figure below shows the functional block diagram per one port pin.



Figure 3-4. Port functional block diagram

#### 3.5.2 Port pins functions

Generally each pin can function as a general-purpose I/O pin or as a dedicated input or output pin.

Note however that some pins have only either a general-purpose input or general-purpose output function, but not both possibilities. Refer to Table 3-7 through Table 3-9 for details. Usually following hard reset all port pins are disabled-both output and input buffers are off.

#### 3.5.2.1 General purpose I/O pins

Usually a value of 00 in CPPAR selects the general-purpose I/O function.

The signal direction is determined by the value in the CPDIR. If a port pin is selected as a general-purpose I/O pin, it can be accessed through the port data register (CPDATx). Data written to the CPDATx is stored in an output latch. If a port pin is configured as an output, the output latch data is driven onto the port pin. In this case, when CPDATx is read, the port pin itself is read. If a port pin is configured as an input, data written to CPDATx is still stored in the output latch, but is prevented from reaching the port pin. In this case, when CPDATx is read, the state of the port pin is read.

#### 3.5.2.2 Dedicated pins

When a port is not configured as a general-purpose I/O pin, it has a dedicated functionality, as described in the following tables.

Note that if an input to a peripheral is not supplied from a pin, a default value is supplied to the on-chip peripheral, as listed in the "Default Input" column in the tables.

#### NOTE

Some output functions can be output on more than one pin. The user can freely configure such functions to be output on more than one pin at once. However, there is typically no advantage in doing so unless there is a large fanout, where it is advantageous to share the load between several pins.

Many input functions can also come from two or three different pins; see Ports Tables.

#### 3.5.3 QUICC engine port interrupts

Ten QUICC Engine port pins may be selected as the source of external interrupts.

This is useful in communication interfaces that require interrupt handling.

# 3.5.4 QE Memory Map/Register Definition

#### **QE** memory map

| Offset<br>address<br>(hex) | Register name                                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------|
| F00C                       | QUICC Engine Port Interrupt Event Register (QE_CEPIER)   | 32                 | w1c    | 0000_0000h  | 3.54.1/114       |
| F010                       | QUICC Engine Port Interrupt Mask Register (QE_CEPIMR)    | 32                 | R/W    | 0000_0000h  | 3.54.2/116       |
| F014                       | QUICC Engine Port Interrupt Control Register (QE_CEPICR) | 32                 | R/W    | 0000_0000h  | 3.54.3/117       |

# 3.54.1 QUICC Engine Port Interrupt Event Register (QE\_CEPIER)

CEPIER carries information on the QUICC Engine ports that caused the interrupt. CEPIER bits are cleared by writing ones; writing zero has no effect.

Address: F000h base + Ch offset = F00Ch



#### **QE\_CEPIER** field descriptions

| Field | Description                                                                          |
|-------|--------------------------------------------------------------------------------------|
|       | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PA4 |
| PA4   |                                                                                      |
|       | 0 No interrupt event occurred on PA4                                                 |
|       | 1 Interrupt event occurred on PA4                                                    |

### **QE\_CEPIER** field descriptions (continued)

| Field       | Description                                                                                    |
|-------------|------------------------------------------------------------------------------------------------|
| 1           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PA8           |
| PA8         | 0 No interrupt event occurred on PA8                                                           |
|             | 1 Interrupt event occurred on PA8                                                              |
| 2           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PA18          |
| PA18        |                                                                                                |
|             | 0 No interrupt event occurred on PA18                                                          |
|             | 1 Interrupt event occurred on PA18                                                             |
| 3<br>PA22   | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PA22          |
| . , , , , , | 0 No interrupt event occurred on PA22                                                          |
|             | 1 Interrupt event occurred on PA22                                                             |
| 4           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PA28          |
| PA28        | 0 No interrupt event occurred on PA28                                                          |
|             | 1 Interrupt event occurred on PA28                                                             |
| 5           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PB0           |
| PB0         |                                                                                                |
|             | No interrupt event occurred on PB0  Interrupt event occurred on PB0                            |
|             | 1 Interrupt event occurred on PB0                                                              |
| 6<br>PB4    | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PB4           |
|             | 0 No interrupt event occurred on PB4                                                           |
|             | 1 Interrupt event occurred on PB4                                                              |
| 7           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PB8           |
| PB8         | 0 No interrupt event occurred on PB8                                                           |
|             | 1 Interrupt event occurred on PB8                                                              |
| 8           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PB14          |
| PB14        | O. No intermed account of a DD44                                                               |
|             | <ul><li>No interrupt event occurred on PB14</li><li>Interrupt event occurred on PB14</li></ul> |
| 9           | QUICC Engine port interrupt event. Indicates whether interrupt event occurred on PB18          |
| PB18        | COICC Engine port interrupt event. Indicates whether interrupt event occurred of PB18          |
|             | 0 No interrupt event occurred on PB18                                                          |
|             | 1 Interrupt event occurred on PB18                                                             |
| 10–31       | This field is reserved.                                                                        |
| -           | Reserved                                                                                       |

#### 3.54.2 QUICC Engine Port Interrupt Mask Register (QE\_CEPIMR)

CEPIER defines the interrupt masking for the individual QUICC Engine port lines. When an interrupt occurs, the corresponding CEPIER bit is set irrespective of CEPIMR state. The QUICC Engine port interrupt is forwarded to QUICC Engine PIC only if one or more non-masked interrupts occurred.

Address: F000h base + 10h offset = F010h

| Bit    | 0        | 1   | 2    | 3    | 4    | 5   | 6   | 7   | 8    | 9    | 10       | 11 | 12 | 13 | 14 | 15 |
|--------|----------|-----|------|------|------|-----|-----|-----|------|------|----------|----|----|----|----|----|
| R<br>W | PA4      | PA8 | PA18 | PA22 | PA28 | PB0 | PB4 | PB8 | PB14 | PB18 | Reserved |    |    |    |    |    |
| Reset  | 0        | 0   | 0    | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0        | 0  | 0  | 0  | 0  | 0  |
| Bit    | 16       | 17  | 18   | 19   | 20   | 21  | 22  | 23  | 24   | 25   | 26       | 27 | 28 | 29 | 30 | 31 |
| R<br>W | HASAN/AN |     |      |      |      |     |     |     |      |      |          |    |    |    |    |    |
| Reset  | 0        | 0   | 0    | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0        | 0  | 0  | 0  | 0  | 0  |

#### **QE\_CEPIMR** field descriptions

| Field     | Description                      |
|-----------|----------------------------------|
| 0         | QUICC Engine port interrupt mask |
| PA4       |                                  |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 1<br>PA8  | QUICC Engine port interrupt mask |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 2         | QUICC Engine port interrupt mask |
| PA18      |                                  |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 3<br>PA22 | QUICC Engine port interrupt mask |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 4<br>PA28 | QUICC Engine port interrupt mask |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 5<br>PB0  | QUICC Engine port interrupt mask |
|           | 0 Interrupt signal is masked     |
|           | 1 Interrupt signal is not masked |
| 6<br>PB4  | QUICC Engine port interrupt mask |

#### **QE\_CEPIMR** field descriptions (continued)

| Field | Description                      |
|-------|----------------------------------|
|       | 0 Interrupt signal is masked     |
|       | 1 Interrupt signal is not masked |
| 7     | QUICC Engine port interrupt mask |
| PB8   |                                  |
|       | 0 Interrupt signal is masked     |
|       | 1 Interrupt signal is not masked |
| 8     | QUICC Engine port interrupt mask |
| PB14  |                                  |
|       | 0 Interrupt signal is masked     |
|       | 1 Interrupt signal is not masked |
| 9     | QUICC Engine port interrupt mask |
| PB18  |                                  |
|       | 0 Interrupt signal is masked     |
|       | 1 Interrupt signal is not masked |
| 10–31 | This field is reserved.          |
| -     | Reserved                         |

# 3.54.3 QUICC Engine Port Interrupt Control Register (QE\_CEPICR)

CEPICR determines whether the corresponding QUICC Engine port line asserts an interrupt request upon either a high-to-low change or nay change in the state of the signal.

Address: F000h base + 14h offset = F014h



#### **QE\_CEPICR** field descriptions

| Field    | Description                                                                                                                                                        |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>PA4 | Edge detection mode.                                                                                                                                               |
| T/A      | <ul> <li>Any change on the state of the QUICC Engine port generates an interrupt.</li> <li>High-to-low change on QUICC Engine port generates interrupt.</li> </ul> |
| 1<br>PA8 | Edge detection mode.                                                                                                                                               |

#### **QE\_CEPICR** field descriptions (continued)

| Field     | Description                                                                                                                                                         |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Any change on the state of the QUICC Engine port generates an interrupt.                                                                                            |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 2         | Edge detection mode.                                                                                                                                                |
| PA18      | O. Any change on the state of the OLUCC Engine next generates an interrupt                                                                                          |
|           | <ul><li>O Any change on the state of the QUICC Engine port generates an interrupt.</li><li>1 High-to-low change on QUICC Engine port generates interrupt.</li></ul> |
| 0         |                                                                                                                                                                     |
| 3<br>PA22 | Edge detection mode.                                                                                                                                                |
| 1,722     | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 4<br>PA28 | Edge detection mode.                                                                                                                                                |
| 17120     | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 5<br>PB0  | Edge detection mode.                                                                                                                                                |
|           | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 6<br>PB4  | Edge detection mode.                                                                                                                                                |
|           | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 7<br>PB8  | Edge detection mode.                                                                                                                                                |
|           | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 8<br>PB14 | Edge detection mode.                                                                                                                                                |
|           | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 9<br>PB18 | Edge detection mode.                                                                                                                                                |
|           | 0 Any change on the state of the QUICC Engine port generates an interrupt.                                                                                          |
|           | 1 High-to-low change on QUICC Engine port generates interrupt.                                                                                                      |
| 10–31     | This field is reserved. Reserved                                                                                                                                    |

#### 3.5.5 Ports Tables

The following tables describe the QUICC Engine port functionality according to the configuration of the port registers. See Direction register (GUTS\_CPDIR1n), and Pin assignment register (GUTS\_CPPAR1n), for additional details.

Some input functions can come from two different pins for flexibility. The figure below shows an example in which two different pins can be selected for one input function. Secondary option programming is relevant only if primary option is programmed to the default value.



Figure 3-8. Primary and Secondary Option Programming

The following tables describe the configuration options for each QUICC Engine Block I/O port pin.

The default value for a primary option is simply a reference to the secondary option for input functions that can come from two different pins. In the secondary option, the programming is relevant only if the primary option is not used for the function.

|     | Pin Functions |          |               |               |           |                  |               |                   |                  |               |                      |               |                  |  |  |
|-----|---------------|----------|---------------|---------------|-----------|------------------|---------------|-------------------|------------------|---------------|----------------------|---------------|------------------|--|--|
|     |               | CPPARAx  | [SE           | Ln]=00        | CPPARAx[S | CPPARAx[SELn]=01 |               |                   | CPPARAx[SELn]=10 |               |                      |               | CPPARAx[SELn]=11 |  |  |
| Pin | Direction     | Function | CPDIRxA[DIRn] | Default Input | Function  | CPDIRxA[DIRn]    | Default Input | Function          | CPDIRxA[DIRn]    | Default Input | Function             | CPDIRxA[DIRn] | Default Input    |  |  |
| PA0 | IN            | GPI_PA0  | 10            | GND           | -         | -                |               | RISC_EXT_<br>REQ3 | 1<br>0           | GND           | UPC1_S_<br>TxADDR[4] | 1<br>0        | PB28             |  |  |
|     | OU<br>T       | GPO_PA0  | 01            |               |           |                  |               | -                 | -                |               | UPC1_M_<br>TxADDR[4] | 0             |                  |  |  |

Table 3-7. Port A Dedicated Pin Assignment

Table 3-7. Port A Dedicated Pin Assignment (continued)

|          | Pin Functions |          |               |                 |                         |               |               |                              |               |               |                      |               |               |
|----------|---------------|----------|---------------|-----------------|-------------------------|---------------|---------------|------------------------------|---------------|---------------|----------------------|---------------|---------------|
|          |               | CPPARAx  | [SE           | L <i>n</i> ]=00 | CPPARAx[S               | ELn           | ]=01          | CPPARAx[S                    | ]=10          | CPPARAx[      | SELn                 | ]=11          |               |
| Pin      | Direction     | Function | CPDIRxA[DIRn] | Default Input   | Function                | CPDIRxA[DIRn] | Default Input | Function                     | CPDIRxA[DIRn] | Default Input | Function             | CPDIRxA[DIRn] | Default Input |
| PA1      | IN            | GPI_PA1  | 10            | GND             | -                       | -             |               | RISC_EXT_<br>REQ1            | 1<br>0        | PB13          | UPC1_S_<br>TxADDR[3] | 1             | PB23          |
|          | OU<br>T       | GPO_PA1  | 01            |                 |                         |               |               | -                            | -             |               | UPC1_M_<br>TxADDR[3] | 0             |               |
| PA2      | IN            | GPI_PA2  | 10            | GND             | -                       | -             |               | RISC_EXT_<br>REQ2            | 1             | PB22          | UPC1_S_<br>RxADDR[4] | 1             | PB25          |
|          | OU<br>T       | GPO_PA2  | 01            |                 |                         |               |               | -                            | -             |               | UPC1_M_<br>RxADDR[4] | 0             |               |
| PA3      | IN            | GPI_PA3  | 10            | GND             | -                       | -             |               | -                            | -             |               | UPC1_S_<br>RxADDR[3] | 1             | PB24          |
|          | OU<br>T       | GPO_PA3  | 01            |                 | STROBE4                 | 0             |               | -                            | -             |               | UPC1_M_<br>RxADDR[3] | 0             |               |
| PA4      | IN            | GPI_PA4  | 10            | GND             | TDMA_TXD[0]<br>(Serial) | 1             | PB23          | Enet1_RX_DV/<br>SER1_CTS_B   | 1             | GND           | -                    | -             |               |
|          | OU<br>T       | GPO_PA4  | 01            |                 |                         |               |               | -                            | -             |               | UPC1_<br>TxDATA[8]   | 0             |               |
| PA5      | IN            | GPI_PA5  | 10            | GND             | TDMA_RXD[0]             | 1             | PB24          | -                            | -             |               | -                    | -             |               |
|          | OU<br>T       | GPO_PA5  | 01            |                 | (Serial)                | 1             |               | Enet1_TX_EN/<br>SER1_RTS_B   | 0             |               | UPC1_<br>TxDATA[9]   | 0             |               |
| PA6      | IN            | GPI_PA6  | 10            | GND             | TDMA_TSYNC              | 1             | PB25          | Enet1_RXD[0]/<br>SER1_RXD[0] | 1<br>0        | GND           | -                    | -             |               |
|          | OU<br>T       | GPO_PA6  | 01            |                 | BRGO9                   | 0             |               | -                            | -             |               | UPC1_<br>TxDATA[10]  | 0             |               |
| PA7      | IN            | GPI_PA7  | 10            | GND             | TDMA_RSYNC              | 1<br>0        | PB26          | -                            | -             |               | -                    | -             |               |
|          | OU<br>T       | GPO_PA7  | 01            |                 | BRGO10                  | 0             |               | Enet1_TXD[0]/<br>SER1_TXD[0] | 0<br>1        |               | UPC1_<br>TxDATA[11]  | 0             |               |
| PA8      | IN            | GPI_PA8  | 10            | GND             | -                       | -             |               | Enet1_RX_ER/<br>SER1_CD_B    | 1<br>0        | GND           | -                    | -             |               |
|          | OU<br>T       | GPO_PA8  | 01            |                 | TDMA_REQ                | 0             |               | -                            | -             |               | UPC1_<br>TxDATA[12]  | 0             |               |
| PA9      | IN            | GPI_PA9  | 10            | GND             | TRB1_IN1                | 1             | GND           | RISC_EXT_<br>REQ4            | 1             | GND           | -                    | -             |               |
|          | OU<br>T       | GPO_PA9  | 01            |                 | -                       | -             |               | Enet1_TXD[1]                 | 0             |               | UPC1_<br>TxDATA[13]  | 0             |               |
| PA1<br>0 | IN            | GPI_PA10 | 10            | GND             | -                       | -             |               | Enet1_RXD[1]                 | 1             | GND           | -                    | -             |               |
|          | OU<br>T       | GPO_PA10 | 01            |                 | TRB1_OUT1               | 0             |               | -                            | -             |               | UPC1_<br>TxDATA[14]  | 0             |               |

Table 3-7. Port A Dedicated Pin Assignment (continued)

|          |           |          |               |                 |                         |               | Pin Fu        | nctions      |               |               |                     |               |               |
|----------|-----------|----------|---------------|-----------------|-------------------------|---------------|---------------|--------------|---------------|---------------|---------------------|---------------|---------------|
|          |           | CPPARAx  | SE            | L <i>n</i> ]=00 | CPPARAx[S               | ELn           | ]=01          | CPPARAx[S    | ELn           | ]=10          | CPPARAx[            | SELn          | ]=11          |
| Pin      | Direction | Function | CPDIRxA[DIRn] | Default Input   | Function                | CPDIRxA[DIRn] | Default Input | Function     | CPDIRxA[DIRn] | Default Input | Function            | CPDIRxA[DIRn] | Default Input |
| PA1<br>1 | IN        | GPI_PA11 | 10            | GND             | TDMB_RXD[1]             | 1<br>0        | GND           | SER3_RXD[1]  | 1<br>0        | GND           | -                   | -             |               |
|          | OU<br>T   | GPO_PA11 | 01            |                 | -                       | -             |               | Enet1_TXD[2] | 0<br>1        |               | UPC1_<br>TxDATA[15] | 0             |               |
| PA1<br>2 | IN        | GPI_PA12 | 10            | GND             | TDMB_RXD[2]             | 1<br>0        | GND           | SER3_RXD[2]  | 1<br>0        | GND           | UPC1_<br>RxDATA[8]  | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA12 | 01            |                 | -                       | -             |               | Enet1_TXD[3] | 0<br>1        |               | -                   | -             |               |
| PA1<br>3 | IN        | GPI_PA13 | 10            | GND             | TDMB_RXD[3]             | 1<br>0        | GND           | SER3_RXD[3]  | 1<br>0        | GND           | UPC1_<br>RxDATA[9]  | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA13 | 01            |                 | -                       | -             |               | Enet1_TX_ER  | 0<br>1        |               | -                   | -             |               |
| PA1<br>4 | IN        | GPI_PA14 | 10            | GND             | -                       | -             |               | Enet1_RXD[2] | 1<br>0        | GND           | UPC1_<br>RxDATA[10] | 1             | GND           |
|          | OU<br>T   | GPO_PA14 | 01            |                 | TDMB_TXD[1]             | 0<br>1        |               | SER3_TXD[1]  | 0<br>1        |               | -                   | -             |               |
| PA1<br>5 | IN        | GPI_PA15 | 10            | GND             | -                       | -             |               | Enet1_RXD[3] | 1<br>0        | GND           | UPC1_<br>RxDATA[11] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA15 | 01            |                 | TDMB_TXD[2]             | 0             |               | SER3_TXD[2]  | 0<br>1        |               | -                   | -             |               |
| PA1<br>6 | IN        | GPI_PA16 | 10            | GND             | -                       | -             |               | Enet1_COL    | 1<br>0        | GND           | UPC1_<br>RxDATA[12] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA16 | 01            |                 | TDMB_TXD[3]             | -             |               | SER3_TXD[3]  | 0<br>1        |               | -                   | -             |               |
| PA1<br>7 | IN        | GPI_PA17 | 10            | GND             | TRB1_IN2                | 1<br>0        | GND           | Enet1_CRS    | 1<br>0        | GND           | UPC1_<br>RxDATA[13] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA17 | 01            |                 | STROBE1                 | 0<br>1        |               | -            | -             |               | -                   | -             |               |
| PA1<br>8 | IN        | GPI_PA18 | 10            | GND             | TDMD_TXD[0]<br>(Serial) | 1             | PB14          | SER7_CTS_B   | 1<br>0        | PB14          | UPC1_<br>RxDATA[14] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA18 | 01            |                 |                         |               |               | PTP_REF_CLK  | 0<br>1        |               | -                   | -             |               |
| PA1<br>9 | IN        | GPI_PA19 | 10            | GND             | TDMD_RXD[0]<br>(Serial) | 1             | PB15          | -            | -             |               | UPC1_<br>RxDATA[15] | 1             | GND           |
|          | OU<br>T   | GPO_PA19 | 01            |                 |                         |               |               | SER7_RTS_B   | 0             |               | PTP_PPS1            | 0             |               |

Table 3-7. Port A Dedicated Pin Assignment (continued)

|          |           |          |               |                 |                      |               | Pin Fu        | nctions            |               |               |                      |               |               |
|----------|-----------|----------|---------------|-----------------|----------------------|---------------|---------------|--------------------|---------------|---------------|----------------------|---------------|---------------|
|          |           | CPPARAx  | SE            | L <i>n</i> ]=00 | CPPARAx[SI           | ELn           | ]=01          | CPPARAx[S          | ELn           | ]=10          | CPPARAx[SI           | ELn           | ]=11          |
| Pin      | Direction | Function | CPDIRxA[DIRn] | Default Input   | Function             | CPDIRxA[DIRn] | Default Input | Function           | CPDIRxA[DIRn] | Default Input | Function             | CPDIRxA[DIRn] | Default Input |
| PA2<br>0 | IN        | GPI_PA20 | 10            | GND             | TDMD_TSYNC           | 1<br>0        | PB16          | SER7_RXD[0]        | 1<br>0        | PB16          | -                    | -             |               |
|          | OU<br>T   | GPO_PA20 | 01            |                 | BRGO9                | 0<br>1        |               | 1588_TRIG_<br>OUT  | 0             |               | UPC1_TxPRTY          | 0             |               |
| PA2<br>1 | IN        | GPI_PA21 | 10            | GND             | TDMD_RSYNC           | 1<br>0        | PB17          | PTP_EXT_<br>TRIGn  | 1<br>0        | PB25          | UPC1_RxPRTY          | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA21 | 01            |                 | BRGO11               | 0<br>1        |               | SER7_TXD[0]        | 0             |               | -                    | -             |               |
| PA2<br>2 | IN        | GPI_PA22 | 10            | GND             | PTP_CLK              | 1<br>0        | GND           | SER7_CD_B          | 1             | PB18          | UPC1_RxSOC           | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA22 | 01            |                 | TDMD_REQ             | 0<br>1        |               | -                  | -             |               | -                    | -             |               |
| PA2<br>3 | IN        | GPI_PA23 | 10            | GND             | CLK1                 | 1<br>0        | GND           | CLK12              | 1             | GND           | -                    | -             |               |
|          | OU<br>T   | GPO_PA23 | 01            |                 | BRGO1                | 0<br>1        |               | -                  | -             |               | UPC1_TxSOC           | 0             |               |
| PA2<br>4 | IN        | GPI_PA24 | 10            | GND             | CLK9                 | 1<br>0        | GND           | -                  | -             |               | UPC1_M_<br>RxCLAV[0] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA24 | 01            |                 | BRGO2                | 0<br>1        |               |                    |               |               | UPC1_S_<br>RxCLAV    | 0             |               |
| PA2<br>5 | IN        | GPI_PA25 | 10            | GND             | TRB1_IN3             | 1<br>0        | GND           | -                  | -             |               | UPC1_M_<br>TxCLAV[0] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA25 | 01            |                 | STROBE4              | 0<br>1        |               |                    |               |               | UPC1_S_<br>TxCLAV    | 0             |               |
| PA2<br>6 | IN        | GPI_PA26 | 10            | GND             | -                    | -             |               | -                  | -             |               | UPC1_S_TxEN_<br>B    | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA26 | 01            |                 | STROBE2              | 0<br>1        |               | TRB1_OUT3          | 0             |               | UPC1_M_<br>TxEN_B[0] | 0             |               |
| PA2<br>7 | IN        | GPI_PA27 | 10            | GND             | CLK6                 | 1<br>0        | GND           | CLK11              | 1             | GND           | UPC1_S_RxEN<br>_B    | 1             | GND           |
|          | OU<br>T   | GPO_PA27 | 01            |                 | BRGO1                | 0<br>1        |               | -                  | -             |               | UPC1_M_<br>RxEN_B[0] | 0             |               |
| PA2<br>8 | IN        | GPI_PA28 | 10            | GND             | RISC_EXT_<br>REQ3/   | 1             | PA0           | SER3_CTS_B         | 1             | GND           | UPC1_S_<br>RxADDR[2] | 1             | PB27          |
|          | OU<br>T   | GPO_PA28 | 01            |                 | TDMB_REQ<br>(Serial) |               |               | QE_GTM_<br>TOUT1_B | 0             |               | UPC1_M_<br>RxADDR[2] | 0             |               |

Table 3-7. Port A Dedicated Pin Assignment (continued)

|          |           |          |               |                 |                         |               | Pin Fu        | nctions             |               |               |                      |               |               |
|----------|-----------|----------|---------------|-----------------|-------------------------|---------------|---------------|---------------------|---------------|---------------|----------------------|---------------|---------------|
|          |           | CPPARAx  | [SE           | L <i>n</i> ]=00 | CPPARAx[S               | ELn           | ]=01          | CPPARAx[S           | ELn           | ]=10          | CPPARAx[SI           | ΞLn           | ]=11          |
| Pin      | Direction | Function | CPDIRxA[DIRn] | Default Input   | Function                | CPDIRxA[DIRn] | Default Input | Function            | CPDIRxA[DIRn] | Default Input | Function             | CPDIRxA[DIRn] | Default Input |
| PA2<br>9 | IN        | GPI_PA29 | 10            | GND             | TDMB_RXD[0]<br>(Serial) | 1<br>1        | GND           | -                   | -             | -             | UPC1_S_<br>TxADDR[1] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA29 | 01            |                 |                         |               |               | SER3_RTS_B          | 0             |               | UPC1_M_<br>TxADDR[1] | 0<br>1        |               |
| PA3<br>0 | IN        | GPI_PA30 | 10            | GND             | TDMB_TSYNC              | 1<br>0        | GND           | SER3_RXD[0]         | 1<br>0        | GND           | UPC1_S_<br>TxADDR[2] | 1<br>0        | PB26          |
|          | OU<br>T   | GPO_PA30 | 01            |                 | -                       | -             |               | -                   | -             |               | UPC1_M_<br>TxADDR[2] | 0<br>1        |               |
| PA3<br>1 | IN        | GPI_PA31 | 10            | GND             | TDMB_RSYNC              | 1<br>0        | GND           | QE_GTM_<br>TGATE1_B | 1<br>0        | GND           | UPC1_S_<br>RxADDR[0] | 1<br>0        | GND           |
|          | OU<br>T   | GPO_PA31 | 01            |                 | -                       | -             |               | SER3_TXD[0]         | 0<br>1        |               | UPC1_M_<br>RxADDR[0] | 0<br>1        |               |

Table 3-8. Port B Dedicated Pin Assignment

|     |           |          |               |                 |                         |               | Pin Fur       | ections   |               |               |                      |               |               |
|-----|-----------|----------|---------------|-----------------|-------------------------|---------------|---------------|-----------|---------------|---------------|----------------------|---------------|---------------|
|     |           | CPPARBx  | [SEI          | ∟ <i>n</i> ]=00 | CPPARBx[SI              | ELn           | ]=01          | CPPARBx[S | ELn           | ]=10          | CPPARBx[SI           | ELn           | ]=11          |
| Pin | Direction | Function | CPDIRXB[DIRn] | Default Input   | Function                | CPDIRxB[DIRn] | Default Input | Function  | CPDIRxB[DIRn] | Default Input | Function             | CPDIRXB[DIRn] | Default Input |
| PB0 | IN        | GPI_PB0  | 10            | GND             | TDMB_TXD[0]<br>(Serial) | 1             | GND           | SER3_CD_B | 1<br>0        | GND           | UPC1_S_<br>RxADDR[1] | 1<br>0        | GND           |
|     | OU<br>T   | GPO_PB0  | 01            |                 |                         |               |               | -         | -             |               | UPC1_M_<br>RxADDR[1] | 0             |               |
| PB1 | IN        | GPI_PB1  | 10            | GND             | CLK5                    | 1<br>0        | GND           | CLK10     | 1<br>0        | GND           | UPC1_S_<br>TxADDR[0] | 1<br>0        | GND           |
|     | OU<br>T   | GPO_PB1  | 01            |                 | BRGO2                   | 0<br>1        |               | -         | -             |               | UPC1_M_<br>TxADDR[0] | 0             |               |
| PB2 | IN        | GPI_PB2  | 10            | GND             | CLK20                   | 1<br>0        | GND           | -         | -             |               | -                    | -             |               |
|     | OU<br>T   | GPO_PB2  | 01            |                 | BRGO7                   | 0<br>1        |               |           |               |               | -                    | -             |               |

Table 3-8. Port B Dedicated Pin Assignment (continued)

|      |           |          |               |                 |                         |               | Pin Fur       | nctions                      |               |               |           |               |               |
|------|-----------|----------|---------------|-----------------|-------------------------|---------------|---------------|------------------------------|---------------|---------------|-----------|---------------|---------------|
|      |           | CPPARBx  | SEI           | ∟ <i>n</i> ]=00 | CPPARBx[SI              | ELn           | ]=01          | CPPARBx[S                    | ELn           | ]=10          | CPPARBx[S | ELn           | ]=11          |
| Pin  | Direction | Function | CPDIRxB[DIRn] | Default Input   | Function                | CPDIRxB[DIRn] | Default Input | Function                     | CPDIRxB[DIRn] | Default Input | Function  | CPDIRxB[DIRn] | Default Input |
| PB3  | IN        | GPI_PB3  | 10            | GND             | CLK19                   | 1<br>0        | GND           | -                            | -             |               | -         | -             |               |
|      | OU<br>T   | GPO_PB3  | 01            |                 | BRGO8                   | 0<br>1        |               |                              |               |               | -         | -             |               |
| PB4  | IN        | GPI_PB4  | 10            | GND             | TDMC_TXD[0]<br>(Serial) | 1             | GND           | Enet5_RX_DV/<br>SER5_CTS_B   | 1             | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB4  | 01            |                 | -                       |               |               | -                            | -             |               |           |               |               |
| PB5  | IN        | GPI_PB5  | 10            | GND             | TDMC_RXD[0]             | 1             | GND           | -                            | -             |               | -         | -             |               |
|      | OU<br>T   | GPO_PB5  | 01            |                 |                         | 1             |               | Enet5_TX_EN/<br>SER5_RTS_B   | 0<br>1        |               |           |               |               |
| PB6  | IN        | GPI_PB6  | 10            | GND             | TDMC_TSYNC              | 1<br>0        | GND           | Enet5_RXD[0]/<br>SER5_RXD[0] | 1<br>0        | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB6  | 01            |                 | -                       | -             |               | -                            | -             |               |           |               |               |
| PB7  | IN        | GPI_PB7  | 10            | GND             | TDMC_RSYNC              | 1<br>0        | GND           | -                            | -             |               | -         | -             |               |
|      | OU<br>T   | GPO_PB7  | 01            |                 | -                       | -             |               | Enet5_TXD[0]/<br>SER5_TXD[0] | 0             |               |           |               |               |
| PB8  | IN        | GPI_PB8  | 10            | GND             | -                       | -             |               | Enet5_RX_ER/<br>SER5_CD_B    | 1<br>0        | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB8  | 01            |                 | TDMC_REQ                | 0<br>1        |               | -                            | -             |               |           |               |               |
| PB9  | IN        | GPI_PB9  | 10            | GND             | RISC_EXT_<br>REQ4       | 1<br>0        | PA9           | Enet5_RXD[1]/<br>SER5_RXD[1] | 1<br>0        | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB9  | 01            |                 | TDMC_TXD[1]             | 0<br>1        |               | TRB1_OUT2                    | 0             |               |           |               |               |
| PB10 | IN        | GPI_PB10 | 10            | GND             | CLK7                    | 1<br>0        | GND           | CLK16                        | 1<br>0        | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB10 | 01            |                 | BRGO5                   | 0<br>1        |               | Enet5_TXD[1]                 | 0<br>1        |               |           |               |               |
| PB11 | IN        | GPI_PB11 | 10            | GND             | CLK13                   | 1<br>0        | GND           | -                            | -             |               | -         | -             |               |
|      | OU<br>T   | GPO_PB11 | 01            |                 | BRGO6                   | 0<br>1        |               | -                            | -             |               |           |               |               |
| PB12 | IN        | GPI_PB12 | 10            | GND             | CLK3                    | 1<br>0        | GND           | TRB1_IN4                     | 1<br>0        | GND           | -         | -             |               |
|      | OU<br>T   | GPO_PB12 | 01            |                 | -                       | -             |               | -                            | -             |               |           |               |               |

Table 3-8. Port B Dedicated Pin Assignment (continued)

|      |           |          |               |                 |                          |               | Pin Fur       | nctions             |               |               |                          |               |               |
|------|-----------|----------|---------------|-----------------|--------------------------|---------------|---------------|---------------------|---------------|---------------|--------------------------|---------------|---------------|
|      |           | CPPARBx  | SEI           | ∟ <i>n</i> ]=00 | CPPARBx[SI               | ELn           | ]=01          | CPPARBx[S           | ELn           | ]=10          | CPPARBx[S                | ELn           | ]=11          |
| Pin  | Direction | Function | CPDIRxB[DIRn] | Default Input   | Function                 | CPDIRxB[DIRn] | Default Input | Function            | CPDIRxB[DIRn] | Default Input | Function                 | CPDIRxB[DIRn] | Default Input |
| PB13 | IN        | GPI_PB13 | 10            | GND             | CLK4                     | 1             | GND           | RISC_EXT_<br>REQ1   | 1             | GND           | -                        | -             |               |
|      | OU<br>T   | GPO_PB13 | 01            |                 | -                        | -             |               | TRB1_OUT4           | 0             |               |                          |               |               |
| PB14 | IN        | GPI_PB14 | 10            | GND             | TDMD_TXD[0]<br>(Serial)  | 1             | GND           | SER7_CTS_B          | 1             | GND           | TDMC_RXD[3]              | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB14 | 01            |                 |                          |               |               | -                   | -             |               | SER5_TXD[3]              | 0<br>1        |               |
| PB15 | IN        | GPI_PB15 | 10            | GND             | TDMD_RXD[0]<br>(Serial)  | 1             | GND           | -                   | -             | -             | SER5_RXD[2]              | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB15 | 01            |                 |                          |               |               | SER7_RTS_B          | 0             |               | TDMC_TXD[2]              | 0             |               |
| PB16 | IN        | GPI_PB16 | 10            | GND             | TDMD_TSYNC               | 1<br>0        | GND           | SER7_RXD[0]         | 1<br>0        | GND           | SER5_RXD[3]              | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB16 | 01            |                 | BRGO9                    | 0             |               | QE_GTM_<br>TOUT3_B  | 0             |               | TDMC_TXD[3]              | 0             |               |
| PB17 | IN        | GPI_PB17 | 10            | GND             | TDMD_RSYNC               | 1<br>0        | GND           | QE_GTM_<br>TGATE3_B | 1<br>0        | GND           | TDMC_RXD[1]              | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB17 | 01            |                 | BRGO11                   | 0             |               | SER7_TXD[0]         | 0             |               | SER5_TXD[1]              | 0             |               |
| PB18 | IN        | GPI_PB18 | 10            | GND             | CLK21                    | 1<br>0        | GND           | SER7_CD_B           | 1<br>0        | GND           | TDMC_RXD[2]              | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB18 | 01            |                 | TDMD_REQ                 | 0<br>1        |               | -                   | -             |               | SER5_TXD[2]              | 0             |               |
| PB19 |           | GPI_PB19 |               | GND             | -                        | -             |               | -                   | -             | -             | SPI1_SPIMOSI<br>(Serial) | 1             | GND           |
|      | OU<br>T   | GPO_PB19 |               |                 | CE_MUX_MDC               | 0<br>1        |               | -                   | -             |               | ,                        | ļ'            |               |
| PB20 | IN        | GPI_PB20 | 10            | GND             | CE_MUX_MDI<br>O (Serial) | 1             | GND           | RISC_EXT_<br>REQ2   | 1<br>0        | GND           | SPI1_SPISEL_<br>B        | 1<br>0        | GND           |
|      | OU<br>T   | GPO_PB20 | 01            |                 |                          |               |               | -                   | -             |               | -                        | -             |               |
| PB21 | IN        | GPI_PB21 | 10            | GND             | -                        | -             |               | QE_GTM_<br>TGATE2_B | -             | GND           | SPI1_SPICLK<br>(Serial)  | 1<br>1        | GND           |
|      | OU<br>T   | GPO_PB21 | 01            |                 |                          |               |               | -                   | -             |               |                          |               |               |
| PB22 | IN        | GPI_PB22 | 10            | GND             | -                        | -             |               | -                   | <u> -</u>     |               | SPI1_SPIMISO             | 1             | GND           |
|      | OU<br>T   | GPO_PB22 | 01            |                 |                          |               |               | QE_GTM_<br>TOUT2_B  | 0<br>1        |               | (Serial)                 | 1             |               |

Table 3-8. Port B Dedicated Pin Assignment (continued)

|      |           |          |               |                 |                         |               | Pin Fur       | nctions             |               |               |                      |               |               |
|------|-----------|----------|---------------|-----------------|-------------------------|---------------|---------------|---------------------|---------------|---------------|----------------------|---------------|---------------|
|      |           | CPPARBx  | SEI           | ∟ <i>n</i> ]=00 | CPPARBx[SI              | ELn           | ]=01          | CPPARBx[SI          | ELn           | ]=10          | CPPARBx[S            | ELn           | ]=11          |
| Pin  | Direction | Function | CPDIRxB[DIRn] | Default Input   | Function                | CPDIRxB[DIRn] | Default Input | Function            | CPDIRxB[DIRn] | Default Input | Function             | CPDIRxB[DIRn] | Default Input |
| PB23 | IN        | GPI_PB23 | 10            | GND             | TDMA_TXD[0]<br>(Serial) | 1             | GND           | -                   | -             |               | UPC1_S_<br>TxADDR[3] | 1             | GND           |
|      | OU<br>T   | GPO_PB23 | 01            |                 |                         |               |               | PTP_REF_CLK         | 0<br>1        |               | UPC1_M_<br>TxADDR[3] | 0             |               |
| PB24 | IN        | GPI_PB24 | 10            | GND             | TDMA_RXD[0]<br>(Serial) | 1             | GND           | -                   | -             |               | UPC1_S_<br>RxADDR[3] | 1 0           | GND           |
|      | OU<br>T   | GPO_PB24 | 01            |                 |                         |               |               | PTP_PPS1            | 0<br>1        |               | UPC1_M_<br>RxADDR[3] | 0             |               |
| PB25 | IN        | GPI_PB25 | 10            | GND             | TDMA_TSYNC              | 1<br>0        | GND           | PTP_EXT_<br>TRIGn   | 1<br>0        | GND           | UPC1_S_<br>RxADDR[4] | 1 0           | GND           |
|      | OU<br>T   | GPO_PB25 | 01            |                 | BRGO9                   | 0<br>1        |               | -                   | -             |               | UPC1_M_<br>RxADDR[4] | 0             |               |
| PB26 | IN        | GPI_PB26 | 10            | GND             | TDMA_RSYNC              | -             | GND           | -                   | -             |               | UPC1_S_<br>TxADDR[2] | 1 0           | GND           |
|      | OU<br>T   | GPO_PB26 | 01            |                 | BRGO10                  | 0<br>1        |               | 1588_TRIG_<br>OUT   | 0<br>1        |               | UPC1_M_<br>TxADDR[2] | 0             |               |
| PB27 | IN        | GPI_PB27 | 10            | GND             | -                       | -             |               | CLK8                | 1<br>0        | GND           | UPC1_S_<br>RxADDR[2] | 1             | GND           |
|      | OU<br>T   | GPO_PB27 | 01            |                 | TDMA_REQ                | 0             |               | -                   | -             |               | UPC1_M_<br>RxADDR[2] | 0             |               |
| PB28 | IN        | GPI_PB28 | 10            | GND             | -                       | -             |               | -                   | -             |               | UPC1_S_<br>TxADDR[4] | 1             | GND           |
|      | OU<br>T   | GPO_PB28 | 01            |                 | -                       | -             |               | -                   | -             |               | UPC1_M_<br>TxADDR[4] | 0             |               |
| PB29 | IN        | GPI_PB29 | 10            | GND             | -                       | -             |               | -                   | -             |               | -                    | -             |               |
|      | OU<br>T   | GPO_PB29 | 01            |                 |                         |               |               | QE_GTM_<br>TOUT4_B  | 0<br>1        |               | STROBE1              | 0             |               |
| PB30 | IN        | GPI_PB30 | 10            | GND             | -                       | -             |               | -                   | -             | -             | -                    | -             |               |
|      | OU<br>T   | GPO_PB30 | 01            |                 |                         |               |               | -                   | -             |               | STROBE3              | 0             |               |
| PB31 | IN        | GPI_PB31 | 10            | GND             | CLK15                   | 1<br>0        | GND           | QE_GTM_<br>TGATE4_B | 1<br>0        | GND           | -                    | -             |               |
|      | OU<br>T   | GPO_PB31 | 01            |                 | BRGO7                   | 0             |               | -                   | -             |               | -                    | -             |               |

Table 3-9. Port C Dedicated Pin Assignment

|     |           |             |               |                |           | Pi            | n Functio      | ons      |               |               |          |               |               |
|-----|-----------|-------------|---------------|----------------|-----------|---------------|----------------|----------|---------------|---------------|----------|---------------|---------------|
|     |           | СРРА        | RCx[SEI       | <i>∟n</i> ]=00 | CPPA      | RCx[SE        | <i>∟n</i> ]=01 | CPPA     | RCx[SEL       | _n]=10        | CPPA     | RCx[SEL       | _n]=11        |
| Pin | Direction | Function    | CPDIRxC[DIRn] | Default Input  | Function  | CPDIRxC[DIRn] | Default Input  | Function | CPDIRxC[DIRn] | Default Input | Function | CPDIRxC[DIRn] | Default Input |
| PC0 | IN        | GPI_P<br>C0 | 10            | GND            | CLK14     | 10            | GND            | -        | -             |               | -        | -             |               |
|     | OUT       | GPO_P<br>C0 | 01            |                | BRGO<br>8 | 01            |                | -        | -             |               | -        | -             |               |

The following table can be used as a reference to identify QE functionalities available on each functional pins of the device.

**Table 3-10. QUICC Engine Multiplex Options** 

|                           | Engine<br>lexing              | Mux<br>Control      | Default<br>Functio |                         |                  | QUIC            | C Engine s      | sub-functi           | onality          |     |       |
|---------------------------|-------------------------------|---------------------|--------------------|-------------------------|------------------|-----------------|-----------------|----------------------|------------------|-----|-------|
| QUICC<br>Engine<br>Signal | Alternat<br>e<br>Functio<br>n | Bit<br>(PMUX<br>CR) | n                  | UTOPIA                  | ENET1/<br>ENET5  | 4xTDM           | 4xUART          | IEEE<br>1588/<br>SPI | GPIO             | CLK | BRG   |
| QUICC E                   | ngine Port                    | A Signals           | 3                  | -                       | -                | -               | -               | -                    | -                | -   |       |
| CE_ PA0                   | LAD8                          | QE1                 | LAD8               | UPC1_<br>TxADD<br>R[4]  | -                | -               | -               | -                    | RISC_<br>GPIO[0] | -   | -     |
| CE_ PA1                   | LGPL0                         | QE4                 | LGPL0              | UPC1_<br>TxADD<br>R[3]  | -                | -               | -               | -                    | RISC_<br>GPIO[1] | -   | -     |
| CE_ PA2                   | LGPL1                         | QE4                 | LGPL1              | UPC1_<br>RxADD<br>R[4]  | -                | -               | -               | -                    | RISC_<br>GPIO[3] | -   | -     |
| CE_ PA3                   | LGPL3                         | QE4                 | LGPL3              | UPC1_<br>RxADD<br>R[3]  | -                | -               | -               | -                    | -                | -   | -     |
| CE_ PA4                   | LA16                          | QE0                 | LA16               | UPC1_<br>TxDATA[<br>8]  | ENET1_<br>RX_DV  | TDMA_T<br>XD[0] | SER1_<br>CTS    | -                    | -                | -   | -     |
| CE_ PA5                   | LA17                          | QE0                 | LA17               | UPC1_<br>TxDATA[<br>9]  | ENET1_<br>TX_EN  | TDMA_<br>RXD[0] | SER1_<br>RTS    | -                    | -                | -   | -     |
| CE_ PA6                   | LA18                          | QE0                 | LA18               | UPC1_<br>TxDATA[<br>10] | ENET1_<br>RXD[0] | TDMA_<br>TSYNC  | SER1_<br>RXD[0] | -                    | -                | -   | BRGO9 |

**Table 3-10. QUICC Engine Multiplex Options (continued)** 

|                           | Engine<br>elexing             | Mux<br>Control      | Default<br>Functio |                         |                  | QUIC            | C Engine s      | sub-function            | onality |     |        |
|---------------------------|-------------------------------|---------------------|--------------------|-------------------------|------------------|-----------------|-----------------|-------------------------|---------|-----|--------|
| QUICC<br>Engine<br>Signal | Alternat<br>e<br>Functio<br>n | Bit<br>(PMUX<br>CR) | n                  | UTOPIA                  | ENET1/<br>ENET5  | 4xTDM           | 4xUART          | IEEE<br>1588/<br>SPI    | GPIO    | CLK | BRG    |
| CE_ PA7                   | LA19                          | QE0                 | LA19               | UPC1_T<br>xDATA[1<br>1] |                  | TDMA_R<br>SYNC  | SER1_<br>TXD[0] | -                       | -       | -   | BRGO10 |
| CE_ PA8                   | LA20                          | QE0                 | LA20               | UPC1_<br>TxDATA[<br>12] | ENET1_<br>RX_ER  | TDMA_R<br>EQ    | SER1_<br>CD     | -                       | -       | -   | -      |
| CE_ PA9                   | LA21                          | QE0                 | LA21               | UPC1_<br>TxDATA[<br>13] | ENET1_<br>TXD[1] | -               | -               | -                       | -       | -   | -      |
| CE_<br>PA10               | LA22                          | QE0                 | LA22               | UPC1_<br>TxDATA[<br>14] | ENET1_<br>RXD[1] | -               | -               | -                       | -       | -   | -      |
| CE_<br>PA11               | LDP0                          | QE0                 | LDP0               | UPC1_<br>TxDATA[<br>15] | ENET1_<br>TXD[2] | TDMB_R<br>XD[1] | SER3_<br>RXD[1] | -                       | -       | -   | -      |
| CE_<br>PA12               | LDP1                          | QE0                 | LDP1               | UPC1_<br>RxDAT<br>A[8]  | ENET1_<br>TXD[3] | TDMB_R<br>XD[2] | SER3_<br>RXD[2] | -                       | -       | -   | -      |
| CE_<br>PA13               | LA28                          | QE0                 | LA28               | UPC1_<br>RxDAT<br>A[9]  | ENET1_<br>TX_ER  | TDMB_R<br>XD[3] | SER3_<br>RXD[3] | -                       | -       | -   | -      |
| CE_<br>PA14               | LGPL5                         | QE0                 | LGPL5              | UPC1_<br>RxDAT<br>A[10] | ENET1_<br>RXD[2] | TDMB_T<br>XD[1] | SER3_<br>TXD[1] | -                       | -       | -   | -      |
| CE_<br>PA15               | USB_PC<br>TL1                 | USB_<br>PCTL        | CE_PA1<br>5        | UPC1_<br>RxDAT<br>A[11] | ENET1_<br>RXD[3] | TDMB_T<br>XD[2] | SER3_<br>TXD[2] | -                       | -       | -   | -      |
| CE_<br>PA16               | LCLK1                         | QE0                 | LCLK1              | UPC1_<br>RxDAT<br>A[12] | ENET1_<br>COL    | TDMB_T<br>XD[3] | SER3_<br>TXD[3] | -                       | -       | -   | -      |
| CE_<br>PA17               | LA23                          | QE0                 | LA23               | UPC1_<br>RxDAT<br>A[13] | ENET1_<br>CRS    | -               | -               | -                       | -       | -   | -      |
| CE_<br>PA18               | LA24                          | QE0                 | LA24               | UPC1_<br>RxDAT<br>A[14] | -                | TDMD_T<br>XD[0] | SER7_<br>CTS    | 1588_<br>clk_out        | -       | -   | -      |
| CE_<br>PA19               | LA25                          | QE0                 | LA25               | UPC1_<br>RxDAT<br>A[15] | -                | TDMD_<br>RXD[0] | SER7_<br>RTS    | 1588_<br>pulse_ou<br>t1 | -       | -   | -      |
| CE_<br>PA20               | LA26                          | QE0                 | LA26               | UPC1_<br>TxPRTY         | -                | TDMD_<br>TSYNC  | SER7_<br>RXD[0] | 1588_<br>trig_out       | -       | -   | BRGO9  |
| CE_<br>PA21               | LA27                          | QE0                 | LA27               | UPC1_<br>RxPRTY         | -                | TDMD_<br>RSYNC  | SER7_<br>TXD[0] | 1588_tri<br>g_in        | -       | -   | BRGO11 |

**Table 3-10. QUICC Engine Multiplex Options (continued)** 

|                           | Engine<br>blexing             | Mux<br>Control      | Default<br>Functio    |                        |                 | QUIC            | C Engine s      | sub-functi           | onality          |                |       |
|---------------------------|-------------------------------|---------------------|-----------------------|------------------------|-----------------|-----------------|-----------------|----------------------|------------------|----------------|-------|
| QUICC<br>Engine<br>Signal | Alternat<br>e<br>Functio<br>n | Bit<br>(PMUX<br>CR) | n                     | UTOPIA                 | ENET1/<br>ENET5 | 4xTDM           | 4xUART          | IEEE<br>1588/<br>SPI | GPIO             | CLK            | BRG   |
| CE_<br>PA22               | LCS4_B                        | QE0                 | LCS4_B                | UPC1_<br>RxSOC         | -               | TDMD_R<br>EQ    | SER7_<br>CD     | 1588_pt<br>p_clk     | -                | -              | -     |
| CE_<br>PA23               | LCS5_B                        | QE0                 | LCS5_B                | UPC1_<br>TxSOC         | -               | -               | -               | -                    | -                | CLK1,<br>CLK12 | BRGO1 |
| CE_<br>PA24               | LCS6_B                        | QE0                 | LCS6_B                | UPC1_<br>RxCLAV[<br>0] | -               | -               | -               | -                    | RISC_<br>GPIO[4] | CLK9           | BRGO2 |
| CE_<br>PA25               | LA29                          | QE0                 | LA29                  | UPC1_<br>TxCLAV[<br>0] | -               | -               | -               | -                    | RISC_<br>GPIO[5] | -              | -     |
| CE_<br>PA26               | LA30                          | QE0                 | LA30                  | UPC1_<br>TxEN[0]       | -               | -               | -               | -                    | -                | -              | -     |
| CE_<br>PA27               | LCS7_B                        | QE0                 | LCS7_B                | UPC1_<br>RxEN_B[<br>0] | -               | -               | -               | -                    | -                | CLK6,<br>CLK11 | BRGO1 |
| CE_<br>PA28               | LCLK0                         | QE2                 | LCLK0                 | UPC1_<br>RxADD<br>R[2] | -               | TDMB_R<br>EQ    | SER3_<br>CTS    | -                    | -                | -              | -     |
| CE_<br>PA29               | CFG_DD<br>R_DEBU<br>G         | QE9                 | CFG_<br>DDR_<br>DEBUG | UPC1_<br>TxADD<br>R[1] | -               | TDMB_R<br>XD[0] | SER3_<br>RTS    | -                    | -                | -              | -     |
| CE_<br>PA30               | LA31                          | QE0                 | LA31                  | UPC1_<br>TxADD<br>R[2] | -               | TDMB_<br>TSYNC  | SER3_<br>RXD[0] | -                    | -                | -              | -     |
| CE_<br>PA31               | none                          |                     | CE_PA3<br>1           | UPC1_<br>RxADD<br>R[0] | -               | TDMB_<br>RSYNC  | SER3_<br>TXD[0] | -                    | -                | -              | -     |
| QUICC E                   | ngine Port                    | B Signals           | S                     |                        |                 |                 |                 |                      |                  | •              |       |
| CE_ PB0                   | none                          |                     | CE_PB0                | UPC1_<br>RxADD<br>R[1] | -               | TDMB_T<br>XD[0] | SER3_<br>CD     | -                    | -                | -              | -     |
| CE_PB1                    | none                          |                     | CE_PB1                | UPC1_<br>TxADD<br>R[0] | -               | -               | -               | -                    | -                | CLK5,<br>CLK10 | BRGO2 |
| CE_ PB2                   | none                          |                     | CE_PB2                | -                      | -               | -               | -               | -                    | RISC_<br>GPIO[6] | CLK20          | BRGO7 |
| CE_ PB3                   | none                          |                     | CE_PB3                | -                      | -               | -               | -               | -                    | RISC_<br>GPIO[7] | CLK19          | BRGO8 |
| CE_ PB4                   | none                          |                     | CE_PB4                | -                      | ENET5_<br>RX_DV | TDMC_T<br>XD[0] | SER5_<br>CTS    | -                    | RISC_<br>GPIO[8] | -              | -     |
| CE_ PB5                   | none                          |                     | CE_PB5                | -                      | ENET5_<br>TX_EN | TDMC_<br>RXD[0] | SER5_<br>RTS    | -                    | RISC_<br>GPIO[9] | -              | -     |

**Table 3-10. QUICC Engine Multiplex Options (continued)** 

|                           | Engine<br>lexing              | Mux<br>Control      | Default<br>Functio     |        |                  | QUIC                                | C Engine s                          | sub-functi           | onality               |                |        |
|---------------------------|-------------------------------|---------------------|------------------------|--------|------------------|-------------------------------------|-------------------------------------|----------------------|-----------------------|----------------|--------|
| QUICC<br>Engine<br>Signal | Alternat<br>e<br>Functio<br>n | Bit<br>(PMUX<br>CR) | n                      | UTOPIA | ENET1/<br>ENET5  | 4xTDM                               | 4xUART                              | IEEE<br>1588/<br>SPI | GPIO                  | CLK            | BRG    |
| CE_ PB6                   | none                          |                     | CE_PB6                 | -      | ENET5_<br>RXD[0] | TDMC_<br>TSYNC                      | SER5_<br>RXD[0]                     | -                    | RISC_<br>GPIO[10<br>] | -              | -      |
| CE_ PB7                   | none                          |                     | CE_PB7                 | -      | ENET5_<br>TXD[0] | TDMC_<br>RSYNC                      | SER5_<br>TXD[0]                     | -                    | RISC_<br>GPIO[11<br>] | -              | -      |
| CE_ PB8                   | USB_<br>PCTL0                 | USB_<br>PCTL        | CE_PB8                 | -      | ENET5_<br>RX_ER  | TDMC_R<br>EQ                        | SER5_<br>CD                         | -                    | RISC_<br>GPIO[12<br>] | -              | -      |
| CE_ PB9                   | LWE1_B                        | QE3                 | LWE1_B                 | -      | ENET5_<br>RXD[1] | TDMC_T<br>XD[1]                     | SER5_<br>RXD[1]                     | -                    | RISC_<br>GPIO[13      | -              | -      |
| CE_<br>PB10               | IRQ6                          | QE0                 | IRQ6                   | -      | ENET5_<br>TXD[1] | -                                   | -                                   | -                    | RISC_<br>GPIO[14<br>] | CLK7,<br>CLK16 | BRGO5  |
| CE_<br>PB11               | none                          |                     | CE_PB1                 | -      | -                | -                                   | -                                   | -                    | RISC_<br>GPIO[15      | CLK13          | BRGO6  |
| CE_<br>PB12               | SDHC_<br>CD_B                 | SDHC_C<br>D         | CE_PB1<br>2            | -      | -                | -                                   | -                                   | -                    | RISC_<br>GPIO[16<br>] | CLK3           | -      |
| CE_<br>PB13               | SDHC_<br>WP                   | SDHC_<br>WP         | CE_PB1                 | -      | -                | -                                   | -                                   | -                    | RISC_<br>GPIO[17      | CLK4           | -      |
| CE_<br>PB14               | UART_<br>CTS_B[0<br>1]        | QE8                 | UART_<br>CTS_B[0<br>1] | -      | -                | TDMC_<br>RXD[3],<br>TDMD_T<br>XD[0] | SER5_<br>TXD[3],<br>SER7_<br>CTS_B  | -                    | -                     | -              | -      |
| CE_<br>PB15               | UART_<br>RTS_B[0<br>1]        | QE8                 | UART_<br>RTS_B[0<br>1] | -      | -                | TDMC_<br>TXD[2],<br>TDMD_<br>RXD[0] | SER5_<br>RXD[2],<br>SER7_<br>RTS_B  | -                    | -                     | -              | -      |
| CE_<br>PB16               | UART_<br>SIN1                 | QE8                 | UART_<br>SIN1          | -      | -                | TDMC_<br>TXD[3],<br>TDMD_<br>TSYNC  | SER5_<br>RXD[3],<br>SER7_<br>RXD[0] | -                    | -                     | -              | BRGO9  |
| CE_<br>PB17               | UART_<br>SOUT1                | QE8                 | UART_<br>SOUT1         | -      | -                | TDMC_<br>RXD[1],<br>TDMD_<br>RSYNC  | SER5_<br>TXD[1],<br>SER7_<br>TXD[0] | -                    | -                     | -              | BRGO11 |
| CE_<br>PB18               | -                             | QE9                 | -                      | -      | -                | TDMC_<br>RXD[2],<br>TDMD_R<br>EQ    | SER5_<br>TXD[2],<br>SER7_<br>CD_B   | -                    | -                     | CLK21          | -      |

### **Table 3-10. QUICC Engine Multiplex Options (continued)**

| QUICC Engine<br>Multiplexing |                               | Mux<br>Control      | Default<br>Functio    | Functio                |                 |                 |        |                         |                       |       |        |
|------------------------------|-------------------------------|---------------------|-----------------------|------------------------|-----------------|-----------------|--------|-------------------------|-----------------------|-------|--------|
| QUICC<br>Engine<br>Signal    | Alternat<br>e<br>Functio<br>n | Bit<br>(PMUX<br>CR) | n                     | UTOPIA                 | ENET1/<br>ENET5 | 4xTDM           | 4xUART | IEEE<br>1588/<br>SPI    | GPIO                  | CLK   | BRG    |
| CE_<br>PB19                  | CFG_<br>MEM_<br>DEBUG         | QE9                 | CFG_<br>MEM_<br>DEBUG | -                      | CE_MU<br>X_MDC  | -               | -      | SPI1_<br>MOSI           | -                     | -     | -      |
| CE_<br>PB20                  | LBCTL                         | QE12                | LBCTL                 | -                      | CE_MU<br>X_MDIO | -               | -      | SPI1_SE<br>L_B          | -                     | -     | -      |
| CE_<br>PB21                  | IIC2_SD<br>A                  | QE10                | IIC2_SD<br>A          | -                      | -               | -               | -      | SPI1_<br>SPICLK         | RISC_<br>GPIO[18<br>] | -     | -      |
| CE_<br>PB22                  | IIC2_SC<br>L                  | QE10                | IIC2_SC<br>L          | -                      | -               | -               | -      | SPI1_<br>MISO           | RISC_<br>GPIO[2]      | -     | -      |
| CE_<br>PB23                  | MSRCID<br>0                   | QE11                | MSRCID<br>0           | UPC1_<br>TxADD<br>R[3] | -               | TDMA_T<br>XD[0] | -      | 1588_<br>clk_out        | -                     | -     | -      |
| CE_<br>PB24                  | MSRCID<br>1                   | QE11                | MSRCID<br>1           | UPC1_<br>RxADD<br>R[3] | -               | TDMA_R<br>XD[0] | -      | 1588_<br>pulse_ou<br>t1 | -                     | -     | -      |
| CE_<br>PB25                  | MSRCID<br>2                   | QE11                | MSRCID<br>2           | UPC1_<br>RxADD<br>R[4] | -               | TDMA_<br>TSYNC  | -      | 1588_<br>trig_in        | -                     | -     | BRGO9  |
| CE_<br>PB26                  | MSRCID<br>3                   | QE11                | MSRCID<br>3           | UPC1_<br>TxADD<br>R[2] | -               | TDMA_<br>RSYNC  | -      | 1588_<br>trig_out       | -                     | -     | BRGO10 |
| CE_<br>PB27                  | MSRCID<br>4                   | QE11                | MSRCID<br>4           | UPC1_<br>RxADD<br>R[2] | -               | TDMA_R<br>EQ    | -      | -                       | -                     | CLK8  | -      |
| CE_<br>PB28                  | MDVAL                         | QE11                | MDVAL                 | UPC1_<br>TxADD<br>R[4] | -               | -               | -      | -                       | -                     | -     | -      |
| CE_<br>PB29                  | none                          |                     | CE_PB2<br>9           | -                      | -               | -               | -      | -                       | RISC_<br>GPIO[19<br>] | -     | -      |
| CE_<br>PB30                  | none                          |                     | CE_PB3<br>0           | -                      | -               | -               | -      | -                       | RISC_<br>GPIO[20<br>] | -     | -      |
| CE_<br>PB31                  | none                          |                     | CE_PB3                | -                      | -               | -               | -      | -                       | -                     | CLK15 | BRGO7  |
| QUICC E                      | ngine Port                    | C Signals           |                       |                        |                 |                 |        |                         |                       |       |        |
| CE_<br>PC0                   | none                          |                     | CE_PC0                | -                      | -               | -               | -      | -                       | -                     | CLK14 | BRGO8  |

Parallel I/O ports

# Chapter 4 Reset, Clocking, and Initialization

This chapter describes the reset, clocking, and some overall initialization of the device, including a definition of the reset configuration signals and the options they select.

#### 4.1 Overview

This chapter describes the reset, clocking, and some overall initialization of the device, including a definition of the reset configuration signals and the options they select.

Additionally, the configuration, control, and status registers are described. Note that other chapters in this book may describe specific aspects of initialization for individual blocks.

The reset, clocking, and control signals provide many options for the operation of the device. Additionally, many modes are selected with reset configuration signals during a hard reset (assertion of HRESET\_B).

# 4.2 Reset external signal descriptions

The table below summarizes the external signals described in this chapter.

Table 4-2 and Table 4-3 have detailed signal descriptions, and Table 4-1 contains references to additional sections that contain more information.

Signal I/O Description References HRESET B Hard reset input. Causes a power-on reset (POR) sequence. Hard reset HRESET REQ B Hard reset request output. An internal block requests that HRESET\_B be Hard reset asserted. SRESET\_B Soft reset input. Causes mcp assertion to the core Soft reset READY P0/ The device has completed the reset operation, and e500 core 0 is not in a power-Power-on reset TRIG\_OUT down (nap, doze, or sleep) or debug state. sequence

Table 4-1. Signal summary

Table 4-1. Signal summary (continued)

| Signal                      | 1/0 | Description                                                                                                                | References                                    |
|-----------------------------|-----|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| READY_P1                    | 0   | The device has completed the reset operation, and e500 core 1 is not in a power-down (nap, doze, or sleep) or debug state. | Power-on reset sequence                       |
| SYSCLK                      | I   | Primary clock input to the device                                                                                          | System clock and DDR controller complex clock |
| RTC                         | I   | Real time clock input                                                                                                      | Real time clock                               |
| SD_REF_CLK/<br>SD_REF_CLK_B | ļ   | SerDes high-speed interface reference clock                                                                                | PCI Express clock                             |
| DDRCLK                      | I   | Reference clock for DDR controller, when running in asynchronous mode                                                      | System clock and DDR controller complex clock |

The following sections describe the reset and clock signals in detail.

### 4.2.1 System control signals

The table below describes some of the device's system control signals.

Power-on reset configuration, describes the signals that also function as reset configuration signals. Note that the CKSTP\_IN\_B and CKSTP\_OUT\_B signals are described in Global Utilities.

Table 4-2. System control signals-detailed signal descriptions

| Signal   | I/O                                                                                                             |                                                                                                                                                               | Description                                                                                                                                                                                 |  |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| HRESET_B | I                                                                                                               |                                                                                                                                                               | t. Causes the device to abort all current internal and external transactions and set all o their default values. HRESET_B may be asserted completely asynchronously with respect r signals. |  |  |  |
|          |                                                                                                                 | State<br>Meaning                                                                                                                                              | Asserted/Negated-See Signal Descriptions and Power-on reset configuration, for more information on the interpretation of other signals during reset.                                        |  |  |  |
|          |                                                                                                                 | Timing                                                                                                                                                        | Assertion/Negation-The P1021 QorIQ Integrated Processor Hardware Specifications gives specific timing information for this signal and the reset configuration signals.                      |  |  |  |
|          |                                                                                                                 |                                                                                                                                                               | t request. Indicates to the board (system in which the device is embedded) that a condition he assertion of HRESET_B has been detected.                                                     |  |  |  |
|          | Meaning eLBC ECC error (see Reset request status and control register (GUTS_triggered a request for hard reset. |                                                                                                                                                               |                                                                                                                                                                                             |  |  |  |
|          |                                                                                                                 |                                                                                                                                                               | Negated-Indicates no reset request.                                                                                                                                                         |  |  |  |
|          |                                                                                                                 | <b>Timing</b> Assertion/Negation-May occur any time, synchronous to the core complex bus c asserted, HRESET_REQ_B does not negate until HRESET_B is asserted. |                                                                                                                                                                                             |  |  |  |

Table 4-2. System control signals-detailed signal descriptions (continued)

| Signal                | I/O |                  | Description                                                                                                                                                                                                                |  |  |
|-----------------------|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| SRESET_B              | I   | configured       | Causes a machine check interrupt to the e500 core. Note that if the e500 core is not to process machine check interrupts, the assertion of SRESET_B causes a core SRESET_B need not be asserted during a hard reset .      |  |  |
|                       |     | State<br>Meaning | Asserted-Asserting SRESET_B causes a machine check interrupt (edge sensitive) to the e500 core. SRESET_B has no effect while HRESET_B is asserted. However, the POR sequence is paused if SRESET_B is asserted during POR. |  |  |
|                       |     | Timing           | Assertion-May occur at any time, asynchronous to any clock.                                                                                                                                                                |  |  |
|                       |     |                  | Negation-Must be asserted for at least two CCB_clk cycles.                                                                                                                                                                 |  |  |
| READY_P0/<br>TRIG_OUT | 0   |                  | ocessor 0. Multiplexed with TRIG_OUT and QUIESCE_B. See Debug Features and not Facility for more information on TOSR and TRIG_OUT.                                                                                         |  |  |
|                       |     | State<br>Meaning | Asserted-Indicates that the device has completed the reset operation, and e500 core 0 is not in a power-down state (nap, doze, or sleep) when TOSR[SEL] equals 0b000. See Power-on reset sequence, for more information.   |  |  |
|                       |     | Timing           | Assertion/Negation-Initial assertion of READY_P0 after reset is synchronous with SYSCLK. Subsequent assertion/negation due to power down modes occurs asynchronously.                                                      |  |  |
| READY_P1              | 0   | Ready pro        | ocessor 1.                                                                                                                                                                                                                 |  |  |
|                       |     | State<br>Meaning | Asserted-Indicates that the device has completed the reset operation, and e500 core 1 is not in a power-down state (nap, doze, or sleep).                                                                                  |  |  |
|                       |     | Timing           | Assertion/Negation-Initial assertion of READY_P1 after reset is synchronous with SYSCLK. Subsequent assertion/negation due to power down modes occurs asynchronously.                                                      |  |  |

### 4.2.2 Clock signals

The table below describes the overall clock signals.

Note that some clock signals are specific to blocks within the device, and although some of their functionality is described in Clocking, they are defined in detail in their respective chapters.

Note that there is also a CLK\_OUT signal; the signal driven on the CLK\_OUT pin is selectable and described in Clock out control register (GUTS\_CLKOCR).

Accessing configuration, control, and status registers

Table 4-3. Clock signals-detailed signal descriptions

| Signal                                                                                                                                                                                                                                                              | l/<br>O                                                                                                                                         |                                                                                                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| e500 core and for all devices and interfaces that operate synchrowith a phased-lock loop (PLL) to create the core complex bus (C clock), which is used by virtually all of the synchronous system to SDRAM and local bus memory controllers, and other internal blo |                                                                                                                                                 | e500 core<br>with a pha<br>clock), wh<br>SDRAM a<br>controllers                                                                                    | ock (SYSCLK). SYSCLK is the primary clock input to the device. It is the clock source for the and for all devices and interfaces that operate synchronously with the core. It is multiplied up ised-lock loop (PLL) to create the core complex bus (CCB) clock (also called the platform ich is used by virtually all of the synchronous system logic, including the L2 cache, the DDR and local bus memory controllers, and other internal blocks such as the DMA and interrupt is. The CCB clock, in turn, feeds the PLL in the e500 core and the PLL that creates the local bry clocks. |  |  |
|                                                                                                                                                                                                                                                                     | <b>Timing</b> Assertion/Negation-See the <i>P1021 QorlQ Integrated Processor Hardware Spec</i> for specific timing information for this signal. |                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| RTC                                                                                                                                                                                                                                                                 | I                                                                                                                                               | specificati<br>maximum                                                                                                                             | clock. May be used (optionally) to clock the time base of the e500 core. The RTC timing ons are given in the <i>P1021 QorlQ Integrated Processor Hardware Specifications</i> , but the frequency should be less than one-quarter of the CCB frequency. See Real time clock. This also be used (optionally) to clock the global timers in the programmable interrupt controller                                                                                                                                                                                                             |  |  |
|                                                                                                                                                                                                                                                                     |                                                                                                                                                 | Timing                                                                                                                                             | Assertion/Negation-See the <i>P1021 QorIQ Integrated Processor Hardware Specifications</i> for specific timing information for this signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| DDRCLK                                                                                                                                                                                                                                                              | I                                                                                                                                               | except in to<br>input is more<br>DDR mem                                                                                                           | roller complex clock. DDRCLK is the clock source for the DDR memory controller complex the case where synchronous mode of operation is selected (see DDR PLL ratio). This clock ultiplied up with a phased-lock loop (PLL) to create the DDR controller complex clock. The nory controller complex clock is the DDR data rate on the external interface unless the given is configured to run in half speed.                                                                                                                                                                               |  |  |
|                                                                                                                                                                                                                                                                     |                                                                                                                                                 | <b>Timing</b> Assertion/Negation-See the <i>P1021 QorIQ Integrated Processor Hardware Specifi</i> for specific timing information for this signal. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |

# 4.3 Accessing configuration, control, and status registers

The configuration, control, and status registers are memory mapped. The set of configuration, control, and status registers occupies a 1-Mbyte region of memory.

Their location is programmable using the CCSR base address register (CCSRBAR). The default base address for the configuration, control, and status registers is  $0x0\_FF70\_0000$  (CCSRBAR =  $0x000F\_F700$ ). CCSRBAR itself is part of the local access block of CCSR memory, which begins at offset 0x0 from CCSRBAR. Because CCSRBAR is at offset 0x0 from the beginning of the local access registers, CCSRBAR always points to itself. The contents of CCSRBAR are broadcast internally in the P1021 to all functional units that need to be able to identify or create configuration transactions.

#### 4.3.1 Updating CCSRBAR

Updates to CCSRBAR that relocate the entire 1-Mbyte region of configuration, control, and status registers require special treatment.

The effect of the update must be guaranteed to be visible by the mapping logic before an access to the new location is seen. To make sure this happens, these guidelines should be followed:

- CCSRBAR should be updated during initial configuration of the device when only one host or controller has access to the device.
  - If the boot sequencer is being used to initialize, it is recommended that the boot sequencer set CCSRBAR to its desired final location.
  - If an external host on PCI Express is configuring the device, it should set CCSRBAR to the desired final location before the e500 core is released to boot.
  - If the e500 core is initializing the device, it should set CCSRBAR to the desired final location before enabling other I/O devices to access the device.
- When the e500 core is writing to CCSRBAR, it should use the following sequence:
  - Read the current value of CCSRBAR using a load word instruction followed by an isync. This forces all accesses to configuration space to complete.
  - Write the new value to CCSRBAR.
  - Perform a load of an address that does not access configuration space or the onchip SRAM, but has an address mapping already in effect (for example, boot ROM). Follow this load with an isync.
  - Read the contents of CCSRBAR from its new location, followed by another isync.

#### 4.3.2 Accessing alternate configuration space

An alternate configuration space can be accessed by configuring the ALTCBAR and ALTCAR registers.

These are intended to be used with the boot sequencer to allow the boot sequencer to access an alternate 1-Mbyte region of configuration space. By loading the proper boot sequencer command in the serial ROM, the base address in the ALTCBAR can be combined with the 20 bits of address offset supplied from the serial ROM to generate a 36-bit address that is mapped to the target specified in ALTCAR. Thus, by configuring these registers, the boot sequencer has access to the entire memory map, one 1-Mbyte block at a time. See Boot sequencer mode, for more information.

#### NOTE

The enable bit in the ALTCAR register should be cleared either by the boot sequencer or by the boot code that executes after the boot sequencer has completed its configuration operations. This prevents problems with incorrect mappings if subsequent configuration of the local access windows uses a different target mapping for the address specified in ALTCBAR.

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### 4.3.3 Boot page translation

When each e500 core comes out of reset, its MMU has one 4-Kbyte page defined at 0x0\_FFFF\_Fnnn.

Each core begins execution with the instruction at effective address 0x0\_FFFF\_FFC. To get this instruction, the core's first instruction fetch is a burst read of boot code from effective address 0x0\_FFFF\_FFE0. For systems in which the boot code resides at a different address, the device provides boot page translation capability. Boot page translation is controlled by the boot page translation register (BPTR). Note that boot page translation affects transactions initiated by each of the two e500 cores in the same manner.

The boot sequencer can enable boot page translation, or the boot page translation can be set up by an external host when the device is configured to be in boot holdoff mode. If translation is to be performed to a page outside the default boot ROM address range defined in the device (8 Mbytes at 0x0\_FF80\_0000 to 0x0\_FFFF\_FFFF as defined in Boot ROM location), the external host or boot sequencer must then also set up a local access window to define the routing of the boot code fetch to the target interface that contains the boot code, because the BPTR defines only the address translation, not the target interface window. See Local address map example, and Boot sequencer mode, for more information.

#### 4.3.4 Boot sequencer

The boot sequencer is a DMA engine that accesses a serial ROM on the I<sup>2</sup>C interface and writes data to CCSR memory or the memory space pointed to by the alternate configuration base address register (ALTCBAR).

See Accessing alternate configuration space. The boot sequencer is enabled by reset configuration pins as described in Boot sequencer configuration. If the boot sequencer is enabled, the e500 core is held in reset until the boot sequencer has completed its operation. For more details, see Boot sequencer mode, in the I<sup>2</sup>C chapter.

# 4.4 Reset Memory Map/Register Definition

This section describes the configuration and control registers that control access to the configuration space and to the boot code as well as guidelines for accessing these regions. It also contains a brief description of the boot sequencer which may be used to initialize configuration registers or memory before the CPU is released to boot.

#### reset memory map

| Offset address (hex) | Register name                                                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 0                    | Configuration, control, and status registers base address register (reset_CCSRBAR) | 32                 | R/W    | 000F_F700h  | 4.4.1/139        |
| 8                    | Alternate configuration base address register (reset_ALTCBAR)                      | 32                 | R/W    | 0000_0000h  | 4.4.2/140        |
| 10                   | Alternate configuration attribute register (reset_ALTCAR)                          | 32                 | R/W    | 0000_0000h  | 4.4.3/140        |
| 20                   | Boot page translation register (reset_BPTR)                                        | 32                 | R/W    | 0000_0000h  | 4.4.4/141        |

# 4.4.1 Configuration, control, and status registers base address register (reset\_CCSRBAR)

Address: 0h base + 0h offset = 0h



#### reset\_CCSRBAR field descriptions

| Field      | Description                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7        | Write reserved, read = 0.                                                                                                                         |
| -          |                                                                                                                                                   |
| 1          | Identifies the 16 most-significant address bits of the window used for configuration accesses. The base address is aligned on a 1-Mbyte boundary. |
| 24–31<br>- | Write reserved, read = 0                                                                                                                          |

# 4.4.2 Alternate configuration base address register (reset\_ALTCBAR)

Address: 0h base + 8h offset = 8h



#### reset\_ALTCBAR field descriptions

| Field             | Description                                                                                             |
|-------------------|---------------------------------------------------------------------------------------------------------|
| 0–7               | Write reserved, read = 0                                                                                |
| -                 |                                                                                                         |
| 8–23<br>BASE_ADDR | Identifies the 16 most significant address bits of an alternate window used for configuration accesses. |
| 24–31             | Write reserved, read = 0                                                                                |
| -                 |                                                                                                         |

# 4.4.3 Alternate configuration attribute register (reset\_ALTCAR)

Address: 0h base + 10h offset = 10h



#### reset\_ALTCAR field descriptions

| Field           | Description                                                                                                                         |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0               | Enable for a second configuration window. Like CCSRBAR, it has a fixed size of 1 Mbyte.                                             |  |  |
| EN              | 0 Second configuration window is disabled.                                                                                          |  |  |
|                 | 1 Second configuration window is enabled.                                                                                           |  |  |
| 1–7             | Write reserved, read = 0                                                                                                            |  |  |
| -               |                                                                                                                                     |  |  |
| 8–11<br>TRGT_ID | Identifies the device ID to target when a transaction hits in the 1-Mbyte address range defined by the second configuration window. |  |  |
|                 | 0000 Reserved                                                                                                                       |  |  |
|                 | 0001 PCI Express interface 2                                                                                                        |  |  |
|                 | 0010 PCI Express interface 1                                                                                                        |  |  |

#### reset\_ALTCAR field descriptions (continued)

| Field |                          | Description                              |  |  |  |  |
|-------|--------------------------|------------------------------------------|--|--|--|--|
|       | 0011                     | Reserved                                 |  |  |  |  |
|       | 0100                     | Local bus controller                     |  |  |  |  |
|       | 0101-1110                | Reserved                                 |  |  |  |  |
|       | 1111                     | Local memory -DDR SDRAM and on-chip SRAM |  |  |  |  |
| 12–31 | Write reserved, read = 0 |                                          |  |  |  |  |
| -     |                          |                                          |  |  |  |  |

# 4.4.4 Boot page translation register (reset\_BPTR)

Address: 0h base + 20h offset = 20h



#### reset\_BPTR field descriptions

| Field             | Description                                                                                                              |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>EN           | Boot page translation enable                                                                                             |  |  |  |
|                   | 0 Boot page is not translated.                                                                                           |  |  |  |
|                   | Boot page is translated as defined in the BPTR[BOOT_PAGE] parameter.                                                     |  |  |  |
| 1–7               | Write reserved, read = 0                                                                                                 |  |  |  |
| -                 |                                                                                                                          |  |  |  |
| 8–31<br>BOOT_PAGE | Translation for boot page. If enabled, the high order 24 bits of accesses to 0x0_FFFF_Fnnn are replaced with this value. |  |  |  |

# 4.5 Functional description

This section describes the various ways to reset the device, the POR configurations, and the clocking on the device.

#### 4.5.1 Reset operations

This device has reset input signals for hard and soft reset operation.

#### 4.5.1.1 Soft reset

Assertion of SRESET\_B causes a machine check interrupt to both e500 cores.

When this occurs, the soft reset flag is recorded in the machine check summary register in the global utilities block so that software can identify the machine check as a soft reset condition. See the *PowerPC e500 Core Complex Reference Manual* for more information on the machine check interrupt and Machine check summary register (GUTS\_MCPSUMR), for more information on the setting of the soft reset flag. Note that if SRESET\_B is asserted before a given e500 core is configured to handle a machine check interrupt, a checkstop condition occurs for that particular core, which causes CKSTP\_OUT0\_B or CKSTP\_OUT1\_B to assert.

#### 4.5.1.2 Hard reset

This device can be completely reset by the assertion of the HRESET\_B input.

The assertion of this signal by external logic is the equivalent of a POR and causes the sequence of events described in Power-on reset sequence.

Refer to the *P1021 QorIQ Integrated Processor Hardware Specifications* for the timing requirements for HRESET\_B assertion and negation.

The hard reset request output signal (HRESET\_REQ\_B) indicates to external logic that a hard reset is being requested by hardware or software. Hardware causes this signal to assert for a boot sequencer failure (see Boot sequencer mode, and EEPROM data format), for a local bus non-correctable ECC error during NAND Flash boot process (see Boot block loading into the FCM buffer RAM), or when either e500 watchdog timer is configured to cause a hard reset request when it expires (See Timer control register group n (PIC\_TCRn); TCR[WRC] field). Software may request a hard reset by setting a bit in a global utilities register; see Reset control register (GUTS\_RSTCR).

#### 4.5.2 Power-on reset sequence

The POR sequence for the device is as follows:

- 1. Power is applied to meet the specifications in the *P1021 QorIQ Integrated Processor Hardware Specifications*.
- 2. The system asserts HRESET\_B and TRST\_B, causing all registers to be initialized to their default states and most I/O drivers to be three-stated (some clock, clock enabled, and system control signals are active).

- 3. The system applies a stable SYSCLK signal and stable PLL configuration inputs, and the device PLL begins locking to SYSCLK.
- 4. The e500 PLL configuration inputs are applied, allowing the e500 PLLs to begin locking to the device clock (the CCB clock).
- 5. The CCB clock is cycled for approximately 100 µs to lock the e500 PLLs.
- 6. The device enables I/O drivers.
- 7. The internal hard resets to the e500 cores are negated and soft resets are negated to the PLLs and other remaining I/O blocks. The PLLs begin to lock.
- 8. When PLL locking is completed, the enhanced local bus FCM is released provided NAND flash is configured as the boot device, as described in Boot ROM location. Once the FCM finishes loading the pages from the NAND Flash device, the boot sequencer, if enabled, is allowed to progress, causing it to load configuration data from serial ROMs on the I<sup>2</sup>C1 interface, as described in Boot sequencer configuration.
- 9. When the local bus FCM and boot sequencer complete, the PCI Express interfaces begin training and are released to accept external requests, and the boot vectors fetched by the e500 cores are allowed to proceed unless processor booting is further held off by POR configuration inputs as described in Boot sequencer configuration. The device is now in its ready state.
- 10. The ASLEEP signal negates synchronized to a rising edge of SYSCLK, indicating the ready state of the system. The ready state for the e500 core is also indicated by the assertion of READY\_P0/TRIG\_OUT if TOSR[SEL] = 000. In this case, READY is asserted with the same rising edge of SYSCLK, to indicate that the e500 core has reached its ready state, allows external system monitors to know basic device status, for example, exactly when the e500 core emerges from reset, or if it is in a low-power mode.

The figure below shows a timing diagram of the POR sequence.



Figure 4-5. Power-on reset sequence

#### 4.5.3 Power-on reset configuration

Various device functions are initialized by sampling certain signals during the assertion of HRESET\_B.

The values of all these signals are sampled into registers while HRESET\_B is asserted. These inputs are to be pulled high or low by external resistors. During HRESET\_B, all other signal drivers connected to these signals must be in the high-impedance state.

Most POR configuration signals have internal pull-up resistors so that if the desired setting is high, there is no need for a pull-up resistor on the board. Other POR configuration signals do not use pull-ups and therefore must be pulled high or low. Refer to the *P1021 QorIQ Integrated Processor Hardware Specifications* for proper resistor values to be used for pulling POR configuration signals high or low.

This section describes the functions and modes configured by POR configuration signals. Note that many reset configuration settings are accessible to software through the following read-only memory-mapped registers described in GUTS Memory Map/Register Definition

- POR PLL status register (PORPLLSR)
- POR boot mode status register (PORBMSR)
- POR device status register (PORDEVSR)
- POR device status register 2 (PORDEVSR2)
- POR debug mode status register (PORDBGMSR)
- General-purpose POR configuration register (GPPORCR)-Reports the value on LAD[0:15] during POR (can be used to external system configuration)

#### NOTE

In the following tables, the binary value 0b0 represents a signal pulled down to GND and a value of 0b1 represents a signal pulled up to  $V_{DD}$ , regardless of the sense of the functional signal name on the signal.

### 4.5.3.1 System PLL ratio

The system PLL inputs establish the clock ratio between the SYSCLK input and the platform clock used by this device.

The platform clock, also called the CCB clock, drives the L2 cache, the DDR SDRAM data rate, and the e500 core complex bus (CCB). There is no default value for this PLL ratio; these signals must be pulled to the desired values. See Minimum frequency requirements, for optimal selection of this ratio with regard to available high-speed interface widths and frequencies. Note that the values latched on these signals during POR are accessible in the PORPLLSR (POR PLL status register), as described in POR PLL ratio status register (GUTS\_PORPLLSR).

The system PLL inputs are shown in the table below.

| Functional signals | Reset configuration name | Value    | CCB Clock : SYSCLK Ratio |
|--------------------|--------------------------|----------|--------------------------|
|                    |                          | (Binary) |                          |
| LA[29:31]          | cfg_sys_pll[0:2]         | 000      | 4:1                      |
| No Default         |                          | 001      | 5:1                      |
|                    |                          | 010      | 6:1                      |
|                    |                          | other    | Reserved                 |

Table 4-8. CCB clock PLL ratio

#### 4.5.3.2 DDR PLL ratio

The DDR PLL inputs, shown in the table below, establish the clock ratio between the DDRCLK input and the DDR complex clock.

The DDR complex clock drives the DDR data rate, which is twice the rate at which commands are issued on the DDR interface. This DDR complex clock domain is asynchronous to the platform clock or CCB clock domain, and is sourced from a separate PLL than the rest of the platform, unless the DDR PLL encoding for synchronous mode operation is selected. When synchronous mode is selected, the DDR complex is driven by the CCB clock, which becomes the DDR data rate. There is no default value for this PLL ratio; these signals must be pulled to the desired values. Note that the encoded values latched on these signals during power-on reset-and not the actual values on the pins-are accessible in PORPLLSR (POR PLL status register), as described in POR PLL ratio status register (GUTS\_PORPLLSR).

| Functional signals                            | Reset configuration name | Value    | DDR complex : DDRCLK ratio |
|-----------------------------------------------|--------------------------|----------|----------------------------|
|                                               |                          | (Binary) |                            |
| TSEC_1588_CLK_OUT,                            | cfg_ddr_pll[0:2]         | 000      | 3:1                        |
| TSEC_1588_PULSE_OUT1,<br>TSEC_1588_PULSE_OUT2 |                          | 001      | 4:1                        |
| No Default                                    |                          | 010      | 6:1                        |
|                                               |                          | 011      | 8:1                        |
|                                               |                          | 100      | 10:1                       |
|                                               |                          | 101      | Reserved                   |
|                                               |                          | 110      | Reserved                   |
|                                               |                          | 111      | Synchronous mode           |

Table 4-9. DDR complex clock PLL ratio

#### 4.5.3.3 e500 core PLL ratios

Table 4-10 and Table 4-11 describe the e500 core clock PLL inputs that program the core PLLs and establish the ratio between the e500 core clocks and the e500 core complex bus (CCB) clock. There are no default values for these PLL ratios; these signals must be

pulled to the desired values. Note that the values latched on these signals during POR are accessible through the memory-mapped PORPLLSR, as described in POR PLL ratio status register (GUTS\_PORPLLSR), and also in the e500 core HID1 register.

Table 4-10. e500 core0 clock PLL ratios

| Functional signals              | Reset configuration name | Value (binary) | e500 core:CCB clock ratio |
|---------------------------------|--------------------------|----------------|---------------------------|
| LBCTL, LALE, LGPL2/LOE_B/LFRE_B | cfg_core0_pll[0:2]       | 000            | Reserved                  |
| No Default                      |                          | 001            | Reserved                  |
|                                 |                          | 010            | 1:1                       |
|                                 |                          | 011            | 3 : 2 (1.5 : 1)           |
|                                 |                          | 100            | 2:1                       |
|                                 |                          | 101            | 5 : 2 (2.5:1)             |
|                                 |                          | 110            | 3:1                       |
|                                 |                          | 111            | Reserved                  |

Table 4-11. e500 core1 clock PLL ratios

| Functional signals           | Reset configuration name | Value (Binary) | e500 core:CCB clock ratio |
|------------------------------|--------------------------|----------------|---------------------------|
| LWE0_B, UART_SOUT1, READY_P1 | cfg_core1_pll[0:2]       | 000            | Reserved                  |
| No Default                   |                          | 001            | Reserved                  |
|                              |                          | 010            | 1:1                       |
|                              |                          | 011            | 3:2(1.5:1)                |
|                              |                          | 100            | 2:1                       |
|                              |                          | 101            | 5 : 2 (2.5:1)             |
|                              |                          | 110            | 3:1                       |
|                              |                          | 111            | Reserved                  |

#### 4.5.3.4 Boot ROM location

This device defines the default boot ROM address range to be 8 Mbytes at address 0x0\_FF80\_0000 to 0x0\_FFFF\_FFFF.

However, which peripheral interface handles these boot ROM accesses can be selected at power on.

The boot ROM location inputs, shown in the table below, select the physical location of boot ROM. Accesses to the boot vector and the default boot ROM region of the local address map are directed to the interface specified by these inputs.

Table 4-12. Boot ROM location

| Functional Signals | Reset Configuration Name | Value    | Meaning                                   |
|--------------------|--------------------------|----------|-------------------------------------------|
|                    |                          | (Binary) |                                           |
| TSEC3_TXD[2:0],    | cfg_rom_loc[0:3]         | 0000     | PCI Express 1                             |
| TSEC1_TX_ER        |                          | 0001     | PCI Express 2                             |
| Default (1111)     |                          | 0010     | Reserved                                  |
|                    |                          | 0011     | Reserved                                  |
|                    |                          | 0100     | DDR controller                            |
|                    |                          | 0101     | Reserved                                  |
|                    |                          | 0110     | On-chip boot ROM-SPI configuration        |
|                    |                          | 0111     | On-chip boot ROM-eSDHC configuration      |
|                    |                          | 1000     | Local bus FCM-8-bit NAND flash small page |
|                    |                          | 1001     | Reserved                                  |
|                    |                          | 1010     | Local bus FCM-8-bit NAND flash large page |
|                    |                          | 1011     | Reserved                                  |
|                    |                          | 1100     | Reserved                                  |
|                    |                          | 1101     | Local bus GPCM-8-bit ROM                  |
|                    |                          | 1110     | Local bus GPCM-16-bit ROM                 |
|                    |                          | 1111     | Local bus GPCM-16-bit ROM (default)       |

Note that the values latched on these signals during POR are accessible through the memory-mapped PORBMSR (POR boot mode status register) described in POR boot mode status register (GUTS\_PORBMSR).

See Local address map example, for an example memory map that relies on the default boot ROM values. Also, see Boot page translation register (reset\_BPTR), for information on translation of the boot page.

### 4.5.3.5 Host/agent configuration

The host/agent reset configuration inputs, shown in the table below, configure the device to act as a host or as an agent of a master on another interface.

If the device is an agent on the PCI Express interfaces, then it is disabled from mastering transactions on that interface until the external host enables it to do so. The external host does this by setting the control registers of the device interfaces appropriately. See details in the PCI Express programming model described in PCI Express Interface Controller.

Note that the values latched on these signals during POR are accessible through the memory-mapped PORBMSR (POR boot mode status register) described in POR boot mode status register (GUTS\_PORBMSR).

Table 4-13. Host/agent configuration

| Functional signals | Reset configuration name | Value    | Meaning                                                                                  |
|--------------------|--------------------------|----------|------------------------------------------------------------------------------------------|
|                    |                          | (Binary) |                                                                                          |
| LWE1_B, LA[18:19]  | cfg_host_agt[0:2]        | 000      | Device acts as an agent on all its PCI Express interfaces.                               |
| Default (111)      |                          | 001      | Device acts as an agent on PCI Express 1 and acts as a host on PCI Express 2.            |
|                    |                          | 010      | Device acts as a host on PCI Express 1 and acts as an agent on PCI Express 2.            |
|                    |                          | 011-110  | Reserved                                                                                 |
|                    |                          | 111      | Device acts as the host processor/root complex for all PCI Express interfaces (default). |

## 4.5.3.6 I/O port selection

This device can be configured with different I/O ports active.

The table below shows the configuration of I/O ports and bit rates (and required reference clocks) that are possible for the PCI Express interfaces.

Note that the POR configuration input cfg\_sgmii3, in combination with cfg\_io\_ports[0:3], determines whether Serdes lane 2 and 3 are used by eTSEC2 and eTSEC3 respectively in SGMII mode.

Also note that when PCI-Express operation is required, the Serdes reference clock must be 100MHz.

Table 4-14. I/O port selection

| Functional signal | Reset configuration name | Value             | Meaning                                                   |
|-------------------|--------------------------|-------------------|-----------------------------------------------------------|
|                   |                          | (Binary)          |                                                           |
| TSEC1_TXD[3:1],   | cfg_io_ports[0:3]        | 0000              | PCI Express 1 (x1) (2.5Gbps) → SerDes lane 0              |
| CFG_IO_PORTS3     |                          |                   | SerDes lanes 1-3 powered down.                            |
| Default (1111)    |                          | 0001              | SerDes lanes 0-3 powered down.                            |
|                   |                          | 0010-0101         | Reserved                                                  |
|                   |                          | 0110              | PCI Express 1 (x4) (2.5 Gbps) → SerDes lanes 0-3          |
|                   |                          | 0111-1101         | Reserved                                                  |
|                   |                          | 1110 <sup>1</sup> | PCI Express 1 (x1) (2.5 Gbps) → SerDes lane 0             |
|                   |                          |                   | PCI Express 2 (x1) (2.5 Gbps) → SerDes lane 1             |
|                   |                          |                   | SGMII eTSEC2 (x1) (1.25Gbps) → SerDes lane 2              |
|                   |                          |                   | SGMII eTSEC3 (x1) (1.25Gbps) → SerDes lane 3 <sup>2</sup> |
|                   |                          | 1111              | PCI Express 1 (x2) (2.5 Gbps) → SerDes lanes 0-1          |
|                   |                          |                   | SGMII eTSEC2 (x1) (1.25Gbps) → SerDes lane 2              |
|                   |                          |                   | SGMII eTSEC3 (x1) (1.25Gbps) → SerDes lane 3 <sup>2</sup> |
|                   |                          |                   | (default)                                                 |

- 1. If the SERDES PLL does not lock, the value of PORDEVSR[IO\_SEL] will be 0001
- 2. Port cfg\_sgmii3 must also be logic 0 in addition for eTSEC3 to operate in SGMII mode.

### 4.5.3.7 CPU boot configuration

The CPU boot configuration input, shown in the table below, specifies the boot configuration mode.

If cfg\_cpu0\_boot (LA27) is sampled low at reset, e500 core 0 is prevented from fetching boot code until configuration by an external master is complete. Similarly, cfg\_cpu1\_boot (LA16) can be used to gate off e500 core 1 from fetching boot code. The external master frees the core 0 and/or core 1 to boot by setting EEBPCR[CPU0\_EN] and/or EEBPCR[CPU1\_EN] in the ECM CCB port configuration register (EEBPCR). See ECM CCB port configuration register (ECM\_EEBPCR), for more information.

Note that the value latched on these signals during POR are accessible through the memory-mapped PORBMSR (POR boot mode status register) described in POR boot mode status register (GUTS\_PORBMSR).

Note also that the values latched on these signals during POR affect all of the PCI Express interfaces' configuration ready mode settings. See Type 0 configuration header registers. When the specific PCI Express module is configured for agent mode and both

cores are configured to be in boot holdoff, the associated configuration register PEX\_CFG\_READY[CFG\_READY] will have a reset value of 1, which indicates a configuration complete status to the transaction layer.

Table 4-15. CPU boot configuration

| Functional signal | Reset configuration name | Value    | Meaning                                                                                                                                                                                       |
|-------------------|--------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                          | (Binary) |                                                                                                                                                                                               |
| LA27, LA16        | cfg_cpu0_boot,           | 00       | CPU boot holdoff mode for both cores. The e500 cores are                                                                                                                                      |
| Default (11)      | cfg_cpu1_boot            |          | prevented from booting until configured by an external master.                                                                                                                                |
|                   |                          | 01       | e500 core 1 is allowed to boot without waiting for configuration by an external master, while e500 core 0 is prevented from booting until configured by an external master or the other core. |
|                   |                          | 10       | e500 core 0 is allowed to boot without waiting for configuration by an external master, while e500 core 1 is prevented from booting until configured by an external master or the other core. |
|                   |                          | 11       | Both e500 cores are allowed to boot without waiting for configuration by an external master (default).                                                                                        |

# 4.5.3.8 Boot sequencer configuration

The boot sequencer configuration options, shown in the table below, allow the boot sequencer to load configuration data from the serial ROM located on the I<sup>2</sup>C1 port before the host tries to configure the device.

These options also specify normal or extended I<sup>2</sup>C addressing modes. See Boot sequencer mode, for more information on the boot sequencer.

Note that the values latched on these signals during POR are accessible through the memory-mapped PORBMSR (POR boot mode status register) described in POR boot mode status register (GUTS\_PORBMSR).

Table 4-16. Boot sequencer configuration

| Functional<br>Signal | Reset Configuration<br>Name | Value<br>(Binary) | Meaning                                                                                                                                                                                      |
|----------------------|-----------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LGPL3/LFWP_B,        | cfg_boot_seq[0:1]           | 00                | Reserved                                                                                                                                                                                     |
| Default (11)         |                             | 01                | Normal I <sup>2</sup> C addressing mode is used. Boot sequencer is enabled and loads configuration information from a ROM on the I <sup>2</sup> C1 interface. A valid ROM must be present.   |
|                      |                             | 10                | Extended I <sup>2</sup> C addressing mode is used. Boot sequencer is enabled and loads configuration information from a ROM on the I <sup>2</sup> C1 interface. A valid ROM must be present. |
|                      |                             | 11                | Boot sequencer is disabled. No I <sup>2</sup> C ROM is accessed (default).                                                                                                                   |

#### NOTE

When the boot sequencer is enabled, the processor core will be held in reset and thus prevented from fetching boot code until the boot sequencer has completed its task, regardless of the state of the CPU boot configuration signal described in CPU boot configuration.

## 4.5.3.9 DDR SDRAM type

DDR3 requires a different voltage level from DDR2.

The table below describes the configuration of the DDR SDRAM type.

| Functional signal | Reset configuration name | Value    | Meaning                           |
|-------------------|--------------------------|----------|-----------------------------------|
|                   |                          | (Binary) |                                   |
| CFG_DRAM_TYPE     | cfg_dram_type            | 0        | DDR2                              |
| Default (1)       |                          |          | 1.8 V, CKE low at reset           |
|                   |                          | 1        | DDR3                              |
|                   |                          |          | 1.5 V, CKE low at reset (default) |

Table 4-17. DDR SDRAM type

## 4.5.3.10 SerDes reference clock configuration

As shown in the table below, two options are available for the frequency of the input SerDes reference clock-either a 100-MHz or 125-MHz LVDS differential clock.

This one clock is applied to an internal PLL whose output creates the clocks used by all four SerDes lanes. The result is always a 1.25-Gbaud transmission/receive rate on each SGMII lane and a 2.5-Gbaud rate on each PCI Express lane.

For any SerDes configuration with PCI Express active, a 100 MHz reference clock must be supplied.

Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2 (POR device status 2 register) described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-18. SerDes reference clock configuration

| Functional signal                       | Reset configuration name | Value<br>(Binary<br>) | Meaning                                                       |
|-----------------------------------------|--------------------------|-----------------------|---------------------------------------------------------------|
| TSEC_1588_ALARM_OUT1 Default (1)        | cfg_srds_refclk          | 0                     | SerDes expects a 125 MHz reference clock frequency.           |
| 2 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 |                          | 1                     | SerDes expects a 100 MHz reference clock frequency (default). |

## 4.5.3.11 eTSECn configuration

The possible configurations for eTSECn are shown in Table 4-19 and Table 4-20.

The values latched on these signals during POR are accessible through the memory-mapped PORDEVSR (POR device status register) described in POR device status register (GUTS\_PORDEVSR). Note that eTSEC1 is MII, RMII, and RGMII, eTSEC2 is SGMII only, and eTSEC3 is RMII, RGMII, and SGMII.

The table below shows the eTSEC1 POR configuration summary.

Table 4-19. eTSEC1 POR configuration summary

| eTSEC1 configuration | cfg_tsec_reduce | cfg_tsec1_prtcl |
|----------------------|-----------------|-----------------|
| MII                  | 1               | 01              |
| RMII                 | 0               | 01              |
| RGMII                | 0               | 10              |

Table 4-20 shows the eTSEC3 POR configuration summary.

Table 4-20. eTSEC3 POR configuration summary

| eTSEC3 configuration | cfg_sgmii3 | cfg_tsec_reduce | cfg_tsec3_prtcl |
|----------------------|------------|-----------------|-----------------|
| SGMII                | 0          | -               | -               |
| RMII                 | 1          | 0               | 01              |
| RGMII                | 1          | 0               | 10              |

#### **NOTE**

eTSEC2 is in SGMII mode only.

#### 4.5.3.11.1 eTSEC3 SGMII mode

The eTSEC3 SGMII mode input, shown in Table 4-21, selects SGMII mode versus parallel mode for enhanced three-speed Ethernet controller (eTSEC) interface 3.

If eTSEC3 is configured to run in SGMII mode, none of the parallel mode configuration inputs are pertinent for configuring eTSEC3's interface. When operating in SGMII mode, the parallel interface pins normally used for eTSEC3 interface are not used, but rather the corresponding SGMII Serdes lane is used.

Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR (POR device status register) described in POR device status register (GUTS\_PORDEVSR).

| Functional signal                | Reset configuration name | Value<br>(Binary<br>) | Meaning                                                                                                     |
|----------------------------------|--------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------|
| TSEC_1588_ALARM_OUT2 Default (1) | cfg_sgmii3               | 0                     | eTSEC3 Ethernet interface operates in SGMII mode and uses SGMII SerDes lane 3 pins.                         |
|                                  |                          | 1                     | eTSEC3 Ethernet interface operates in standard parallel interface mode and uses the TSEC3_* pins (default). |

Table 4-21. eTSEC3 SGMII mode configuration

#### 4.5.3.11.2 eTSEC1 width

The eTSEC width input, shown in Table 4-22, selects standard versus reduced width for three-speed Ethernet controller interfaces operating in parallel mode.

The value latched on this signal during POR is accessible through the memory-mapped PORDEVSR (POR device status register) described in POR device status register (GUTS\_PORDEVSR).

| Functional signals | Reset<br>configuration<br>name | Value<br>(Binary<br>) | Meaning                                                                             |
|--------------------|--------------------------------|-----------------------|-------------------------------------------------------------------------------------|
| EC_MDC Default (1) | cfg_tsec_reduce                | 0                     | eTSEC1 Ethernet interface operates in reduced pin mode (either RGMII or RMII mode). |
| 20.55.5.(1)        |                                | 1                     | eTSEC1 Ethernet interface operates in standard width MII mode (default).            |

Table 4-22. eTSEC1 width configuration

## 4.5.3.11.3 eTSEC1 protocol

The eTSEC1 protocol inputs, shown in the table below, select the protocol (MII) used by the eTSEC1 controller when operating in parallel mode.

Note that the value latched on these signals during POR is accessible through the memory-mapped PORDEVSR (POR device status register) described in POR device status register (GUTS\_PORDEVSR).

| Functional signals      | Reset<br>configuration<br>name | Value<br>(Binary) | Meaning                                                                                                                     |
|-------------------------|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------|
| TSEC1_TXD0,             | cfg_tsec1_prtcl[0:1]           | 00                | Reserved                                                                                                                    |
| TSEC3_TXD3 Default (11) |                                | 01                | The eTSEC1 controller operates using the MII protocol (or RMII if configured in reduced mode as described in eTSEC1 width). |
|                         |                                | 10                | The eTSEC1 controller operates using the RGMII protocol if configured in reduced mode as described in eTSEC1 width.         |
|                         |                                | 11                | Reserved                                                                                                                    |

Table 4-23. eTSEC1 protocol configuration

### 4.5.3.11.4 eTSEC3 protocol

The eTSEC3 protocol inputs, shown in the table below, select the protocol (RMII or RGMII) used by the eTSEC3 controller when operating in parallel mode.

This input only affects operation of eTSEC3 if it is not configured to operate in SGMII mode.

The value latched on these signals during POR is accessible through the memory-mapped PORDEVSR (POR device status register) described in POR device status register (GUTS\_PORDEVSR).

Note that parallel mode operation for eTSEC3 is only available when eTSEC1 is configured for reduced-mode width.

| Functional signals       | Reset<br>configuration<br>name | Value<br>(Binary) | Meaning                                                                                             |
|--------------------------|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------|
| UART_RTS0_B,             | cfg_tsec3_prtcl[0:1]           | 00                | Reserved.                                                                                           |
| UART_RTS1_B Default (11) |                                | 01                | The eTSEC3 controller operates using the RMII protocol if not configured to operate in SGMII mode.  |
|                          |                                | 10                | The eTSEC3 controller operates using the RGMII protocol if not configured to operate in SGMII mode. |
|                          |                                | 11                | Reserved                                                                                            |

Table 4-24. eTSEC3 protocol configuration

### 4.5.3.12 Memory debug configuration

The memory debug configuration input, shown in the table below, selects which debug outputs (DDR or LBC memory controller) are driven onto the MSRCID and MDVAL debug signals.

Note that the value latched on this signal during POR is accessible through the memory-mapped PORDBGMSR (POR debug mode register) described in POR debug mode status register (GUTS\_PORDBGMSR).

| Functional signal                      | Reset configuration name | Value    | Meaning                                                                                                   |
|----------------------------------------|--------------------------|----------|-----------------------------------------------------------------------------------------------------------|
|                                        |                          | (Binary) |                                                                                                           |
| CFG_MEM_DEBUG <sup>1</sup> Default (1) | cfg_mem_debug            | 0        | Debug information from the enhanced local bus controller (eLBC) is driven on the MSRCID and MDVAL signals |
|                                        |                          | 1        | Debug information from the DDR SDRAM controller is driven on the MSRCID and MDVAL signals (default).      |

Table 4-25. Memory debug configuration

## 4.5.3.13 DDR debug configuration

The DDR debug configuration input, shown in the table below, enables a DDR memory controller debug mode in which the DDR SDRAM source ID field and data valid strobe are driven onto the ECC pins.

ECC checking and generation are disabled in this case. ECC signals driven from the SDRAMs must be electrically disconnected from the ECC I/O pins of the device in this mode.

| Functional signal            | Reset configuration name | Value    | Meaning                                                                                                                      |
|------------------------------|--------------------------|----------|------------------------------------------------------------------------------------------------------------------------------|
|                              |                          | (Binary) |                                                                                                                              |
| CFG_DDR_DEBUG<br>Default (1) | cfg_ddr_debug            |          | Debug information is driven on the ECC pins instead of normal ECC I/O. ECC signals from memory devices must be disconnected. |
|                              |                          | 1        | Debug information is not driven on ECC pins. ECC pins function in their normal mode (default).                               |

Table 4-26. DDR debug configuration

Note that the value latched on this signal during POR is accessible through the memory-mapped PORDBGMSR (POR debug mode register) described in POR debug mode status register (GUTS\_PORDBGMSR).

<sup>1.</sup> This functionality is available only when QUICC Engine pins are not muxed on debug pads.

# 4.5.3.14 General-purpose POR configuration

The LBC address/data bus inputs, shown in the table below, configure the value of the general-purpose POR configuration register defined in General-purpose POR configuration register (GUTS\_GPPORCR).

This register is intended to facilitate POR configuration of user systems. A value placed on LAD[0:15] during POR is captured and stored (read only) in the GPPORCR. Software can then use this value to inform the operating system about initial system configuration. Typical interpretations include circuit board type, board ID number, or a list of available peripherals.

 Table 4-27.
 General-purpose POR configuration

| Functional signals | Reset configuration name | Value<br>(Binary) | Meaning                                                  |
|--------------------|--------------------------|-------------------|----------------------------------------------------------|
| LAD[0:15]          | cfg_gpinput[0:15]        |                   | General-purpose POR configuration vector to be placed in |
| No Default         |                          |                   | GPPORCR.                                                 |

## 4.5.3.15 Engineering use POR configuration

The POR configuration inputs shown in the table below may be used in the future to control functionality.

It is advised that boards are built with the ability to pullup or pulldown these pins. Note that the value latched on these signals during POR are accessible through the PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-28. Engineering use

| Functional signals | Reset configuration name      | Value         | Meaning           |
|--------------------|-------------------------------|---------------|-------------------|
|                    |                               | (Binary)      |                   |
|                    | cfg_eng_use[0:2],             | 1_1111        | Default operation |
| MSRCID[4]          | cfg_eng_use[3],cfg_eng_use[6] | 0_0000-1_1110 | Reserved          |
| Default (1_1111)   |                               |               |                   |

# 4.5.3.16 eLBC ECC enable configuration

The POR configuration input shown in the table below is used to enable eLBC ECC checking on the external local bus interface on boot.

Table 4-29. eLBC ECC enable

| Functional signals | Reset configuration name | Value<br>(Binary) | Meaning                                          |
|--------------------|--------------------------|-------------------|--------------------------------------------------|
| MSRCID0            | cfg_elbc_ecc             | 1                 | Default operation: eLBC ECC checking is enabled. |
| Default (1)        |                          | 0                 | eLBC ECC checking is disabled.                   |

## **4.5.3.17** System speed

The SYSCLK speed configuration input, shown in the table below, configures internal logic for proper operation with the SYSCLK clock frequencies in use.

The default setting is appropriate for SYSCLK operating at or above 66 MHz. If this configuration is not set properly, behavior of the system may be unreliable. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-30. System speed

| Functional signals | Reset configuration name | Value<br>(Binary) | Meaning                                           |
|--------------------|--------------------------|-------------------|---------------------------------------------------|
| LA28               | cfg_sys_speed            | 0                 | Reserved                                          |
| Default (1)        |                          | 1                 | SYSCLK frequency is at or above 66 MHz (default). |

## 4.5.3.18 Platform speed

The platform speed configuration input, shown in the table below, configures internal logic for proper operation with the platform clock frequencies in use.

If this configuration is not set properly, behavior of the system may be unreliable. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-31. Platform speed

| Functional signals  | Reset configuration name | Value<br>(Binary) | Meaning                                                      |
|---------------------|--------------------------|-------------------|--------------------------------------------------------------|
| LA23<br>Default (1) | cfg_plat_speed           | 0                 | Platform clock frequency is above 267 MHz and below 300 MHz. |
| Boladit (1)         |                          | 1                 | Platform clock frequency is at or above 300 MHz (default).   |

# 4.5.3.19 Core 0 speed

The core 0 speed configuration input, shown in the table below, configures internal logic for proper operation with the core 0 clock frequencies in use.

The default setting is appropriate for core 0 operating at or above 500 MHz. For low speed operation (core 0 below 500 MHz) this POR configuration input should be low during HRESET. If this configuration is not set properly, behavior of the system may be unreliable. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-32. Core 0 speed

| Functional signals | Reset configuration name | Value<br>(Binary) | Meaning                                                               |
|--------------------|--------------------------|-------------------|-----------------------------------------------------------------------|
| LA24               | cfg_core0_speed          | 0                 | Core 0 clock frequency is less than 500 MHz.                          |
| Default (1)        |                          | 1                 | Core 0 clock frequency is greater than or equal to 500 MHz (default). |

# 4.5.3.20 Core 1 speed

The core 1 speed configuration input, shown in the table below, configures internal logic for proper operation with the core 1 clock frequencies in use.

The default setting is appropriate for core 1 operating at or above 500 MHz. For low speed operation (core 1 below 500 MHz) this POR configuration input should be low during HRESET. If this configuration is not set properly, behavior of the system may be

#### **Functional description**

unreliable. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-33. Core 1 speed

| Functional signals | Reset configuration name | Value<br>(binary) | Meaning                                                               |
|--------------------|--------------------------|-------------------|-----------------------------------------------------------------------|
| LA25               | cfg_core1_speed          | 0                 | Core 1 clock frequency is less than 500 MHz.                          |
| Default (1)        |                          | 1                 | Core 1 clock frequency is greater than or equal to 500 MHz (default). |

### 4.5.3.21 DDR speed

The DDR speed configuration input, shown in the table below, configures internal logic for proper operation with the DDR data rate in use.

The default setting is appropriate for the DDR data rate operating at or above 500 MT/s. For low speed operation (DDR data rate below 500 MT/s), this POR configuration input should be low during HRESET. If this configuration is not set properly, behavior of the system may be unreliable. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

Table 4-34. DDR speed

| Functional signals | Reset configuration name | Value<br>(Binary) | Meaning                                                       |
|--------------------|--------------------------|-------------------|---------------------------------------------------------------|
| LA26               | cfg_ddr_speed            | 0                 | DDR data rate is less than 500 MT/s.                          |
| Default (1)        |                          | 1                 | DDR data rate is greater than or equal to 500 MT/s (default). |

## 4.5.3.22 eSDHC card-detect polarity select

The eSDHC card-detect polarity select pin sets the polarity of the eSDHC card-detect pin. Note that the value latched on this signal during POR is accessible through the memory-mapped PORDEVSR2, described in POR device status register 2 (GUTS\_PORDEVSR2).

The table below shows the eSDHC card-detect polarity select.

Table 4-35. SDHC card detect polarity select

| Functional signals | Reset configuration name | Value<br>(binary) | Meaning                                                  |
|--------------------|--------------------------|-------------------|----------------------------------------------------------|
| TSEC3_TX_EN        | cfg_sdhc_cd_pol_sel      | 0                 | The eSDHC card-detect polarity is inverted.              |
| Default (1)        |                          | 1                 | The eSDHC card-detect polarity is not inverted.(default) |

# 4.5.4 Voltage selection configuration

This device supports multiple supply voltages on its I/O supplies.

The signals used for these voltage selections are not POR configurations. This section describes the encoding used to select the voltage level for each I/O supply.

#### NOTE

Incorrect voltage select settings can lead to irreversible device damage. Follow this section carefully.

For proper use, the voltage select device input signals LVDD\_SEL, BVDD\_VSEL[0:1], and CVDD\_VSEL[0:1] must be statically tied to reflect the voltage applied on the LVDD, BVDD, and CVDD I/O supplies respectively.

The table below defines the voltage select inputs.

Table 4-36. I/O supply voltage select settings

| Voltage select input | Voltage select setting <sup>1</sup> | Supply Voltage | Interfaces effected             |
|----------------------|-------------------------------------|----------------|---------------------------------|
| LVDD_VSEL            | 0                                   | LVDD = 3.3 V   | eTSEC1, 3; Ethernet management; |
|                      | 1                                   | LVDD = 2.5 V   | 1588                            |
| BVDD_VSEL[0:1]       | 00                                  | BVDD = 3.3 V   | Local Bus                       |
|                      | 01                                  | BVDD = 2.5 V   |                                 |
|                      | 10                                  | BVDD = 1.8 V   |                                 |
|                      | 11                                  | BVDD = 3.3 V   |                                 |
| CVDD_VSEL[0:1]       | 00                                  | CVDD = 3.3 V   | USB, eSDHC, eSPI                |
|                      | 01                                  | CVDD = 2.5 V   |                                 |
|                      | 10                                  | CVDD = 1.8 V   | ]                               |
|                      | 11                                  | CVDD = 3.3 V   | 1                               |

1. Logic 0 corresponds with a static tie to GND, while a logic 1 corresponds with a static tie to OVDD (3.3 V).

#### **Functional description**

As an example, for local bus operation at 2.5 V, the BVDD\_VSEL[0] and BVDD\_VSEL[1] device inputs must be configured to 01 and thus be tied on the board to GND and OVDD respectively. For 2.5 V operation, tying BVDD\_VSEL[0] and BVDD\_VSEL[1] to anything except GND and OVDD respectively can lead to irreversible device damage.

## 4.5.5 Clocking

The table below shows the operational frequency of various blocks.

Table 4-37. Operational frequency

| Functional module   | Operating frequency |
|---------------------|---------------------|
| L2 Cache            | CCB                 |
| Coherency module    | CCB                 |
| eTSEC               | CCB/2               |
| MPIC                | CCB                 |
| eLBC                | CCB                 |
| DMA                 | CCB/2               |
| Performance monitor | CCB                 |
| SEC                 | CCB/2               |
| Debug/watchpoint    | CCB                 |
| PCI Express         | CCB/2               |
| I <sup>2</sup> C    | CCB/2               |
| DUART               | CCB                 |
| USB controller      | CCB/2               |
| eSDHC               | CCB/2               |
| eSPI                | CCB/2               |
| QE                  | CCB                 |

The following paragraphs describe the clocking within the device.

### 4.5.5.1 System clock and DDR controller complex clock

This device takes a single input clock, SYSCLK, as its primary clock source for the e500 core and all of the devices and interfaces that operate synchronously with the core.

As shown in Figure 4-6, the SYSCLK input (frequency) is multiplied up using a phase lock loop (PLL) to create the core complex bus (CCB) clock (also called the platform clock). The CCB clock is used by virtually all of the synchronous system logic, including the L2 cache, and other internal blocks such as the DMA and interrupt controller. The

CCB clock also feeds the PLLs in the e500 cores. Note that the divide-by-two CCB clock divider and the divide-by-*n* CCB clock divider, shown in Figure 4-6, are located in the DDR and local bus blocks, respectively.

The DDR memory controller complex may use the platform clock and thus have operation of both DDR interfaces be synchronous with the platform. Alternately, an independent clock, DDRCLK, may be multiplied up using a separate PLL to create a unique DDR memory controller complex clock. In this case, the DDR complex operates asynchronous with respect to the platform clock.

#### **Functional description**



Figure 4-6. Clock subsystem block diagram

### 4.5.5.2 PCI Express clock

The clocks for the PCI Express interfaces are derived from a PLL in the SerDes block.

This PLL is driven by a reference clock (SD\_REF\_CLK/SD\_REF\_CLK\_B) whose input frequency is a function of the bit rate being used as shown in the table below.

Table 4-38. High speed interface clocking

| Interfaces  | Bit Rate | Reference clock frequency |
|-------------|----------|---------------------------|
| PCI Express | 2.5 Gbps | 100 MHz                   |

### 4.5.5.2.1 Minimum frequency requirements

I/O port selection, describes various high-speed interface configuration options.

CCB clock frequency must be considered for proper operation of such interfaces as described below.

For proper PCI Express operation, the CCB clock frequency must be greater than:

See Link width, for PCI Express interface width details.

### 4.5.5.3 SGMII clocks

Clocks for the SGMII high speed interfaces on this device are derived from a PLL in the SerDes block.

This PLL is driven by a reference clock (SD\_REF\_CLK/SD\_REF\_CLK\_B) whose input frequency may be either 100-MHz or 125-MHz to obtain the required 1.25-Gbaud rate for each lane. The configuration information of the speed of the reference clock must be set properly on the POR configuration pin cfg\_srds\_sgmii\_refclk (see SerDes reference clock configuration).

#### 4.5.5.4 Ethernet clocks

The Ethernet blocks operate asynchronously with respect to the rest of the device.

#### **Functional description**

These blocks use receive and transmit clocks supplied by their respective PHY chips, plus a 125-MHz clock input for gigabit protocols. Data transfers are synchronized to the CCB clock internally.

#### 4.5.5.5 Real time clock

As shown in the figure below, the real time clock (RTC) input can optionally be used to clock the e500 core timer facilities.

RTC can also be used (optionally) by the device programmable interrupt controller (PIC) global timer facilities. The RTC is separate from the e500 core clock and is intended to support relatively low frequency timing applications. The RTC frequency range is specified in the *P1021 QorIQ Integrated Processor Hardware Specifications*, but the maximum value should not exceed one-quarter of the CCB frequency.

Before being distributed to the core time base, RTC is sampled and synchronized with the CCB clock.

The clock source for the core time base is specified by two fields in HID0: time base enable (TBEN), and select time base clock (SEL\_TBCLK). If the time base is enabled, (HID0[TBEN] is set), the clock source is determined as follows:

- HID0[SEL TBCLK] = 0, the time base is updated every 8 CCB clocks
- HID0[SEL\_TBCLK] = 1, the time base is updated on the rising edge of RTC

The default source of the time base is the CCB clock divided by eight. For more details, see the *PowerPC e500 Core Complex Reference Manual*.

Timer control register group n (PIC\_TCRn), provides additional information on the use of the RTC signal to clock the global timers in the PIC unit.



**Note:** The logic circuits shown depict functional relationships only; they do not represent physical implementation details.

Figure 4-7. RTC and core timer facilities clocking options

# 4.6 Initialization/applications information

Selecting on-chip ROM in boot ROM location, see Table 4-12, causes the e500 CPU to fetch data from the on-chip ROM.

The on-chip ROM is selected by configuring the POR config pins *cfg\_rom\_loc[0:3]*. Two different configurations are provided for boot from the on-chip ROM: boot from eSPI and boot from eSDHC.

### 4.6.1 eSDHC boot

This section explains how to boot from eSDHC.

It discusses the following:

- eSDHC boot overview
- eSDHC boot features
- SD/MMC card data structure

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Initialization/applications information

- eSDHC controller initial configuration
- eSDHC controller boot sequence
- eSDHC boot error handling

#### 4.6.1.1 eSDHC boot overview

This device is capable of loading initialization code from a memory device that is connected to the eSDHC controller interface.

This device can be either a SD card, or MMC card or other variants compatible with these devices. The term SD/MMC will be used when referring to the memory device.

Boot from eSDHC is supported by the device using an on-chip ROM which contains the basic eSDHC device driver and the code to perform block copy from SD/MMC to any target memory. Selecting on-chip ROM in boot ROM location (see Table 4-12) causes the e500 CPU to fetch data from the on-chip ROM. The on-chip ROM is selected by configuring the POR config pins  $cfg\_rom\_loc[0:3]$ . Prior to boot, the user must ensure that the SD/MMC card to boot from is inserted.

After the device has completed the reset sequence, if the ROM location selects the on-chip ROM eSDHC Boot configuration, the e500 core starts to execute code from the internal on-chip ROM. The e500 core configures the eSDHC controller, enabling it to communicate with the external SD/MMC card. The SD/MMC card should contain a specific data structure with control words, device configuration information and initialization code. The on-chip ROM boot code uses the information from the SD/MMC card content to configure the device, and to copy the initialization code to a target memory device (for example, the DDR) through the eSDHC interface. After all the code has been copied, the e500 core starts to execute the code from the target memory device.

There are several different ways a user may utilize the eSDHC boot feature. The simplest is for the on-chip ROM to copy an entire operating system boot image into system memory, and then jump to it to begin execution. However, this may be many megabytes and in some situations may be sub-optimal, since only 1-bit mode is used during booting.

A more advanced option is for the on-chip ROM to only copy a small user-customized subroutine, which configures the eSDHC in an optimal way. The user-customised subroutine then copies the rest of the boot code potentially much faster than the on-chip ROM software can achieve. For example, the user-customised subroutine may utilize 4-bit or 8-bit eSDHC interfaces, or support new SD or MMC format revisions, or increase the external clock frequency based on knowledge of the exact frequency that the device is operating at.

#### 4.6.1.2 eSDHC boot features

The main features are as follows:

- Provides mechanism to load initialization code from the following external devices:
  - SD memory cards, including the memory portion of SD Combo cards (up to and including version 2.0)
  - MMC, RS-MMC and MMC*plus* (up to and including version 4.2)
  - SDHC cards (SD High Capacity, from 4 GByte to 32 GByte)
- Boot from the following devices is not supported
  - SDIO and miniSDIO cards which are not SD Combo cards and consequently have no memory
  - Locked (password-protected) SD/MMC cards
  - Secured Mode of SD cards (SD Card Specification Part 3: Security Specification)
- Simple data structure in SD/MMC card
- BOOT signature will be checked to validate that the SD/MMC card contains valid code
- Supports variable code length in SD/MMC card
- Flexible target memory device
- Supports target memory configuration controlled by the user
- Only 1-bit operation is supported for boot (even if the SD/MMC card supports 4 or 8-bit parallel access).
- Initial setting will use a serial clock below 400 kHz; the SD/MMC internal registers are read by initialization code and parsed to determine the optimal clock frequency supported by the SD/MMC card inserted.
- High speed cards are supported (up to 50 MHz SD and 52 MHz MMC).
- Control word will allow for user modification
- There must be precisely one device connected on the eSDHC bus. In particular, multiple MMC devices sharing the one bus are not supported.
- Compatible with FAT12/FAT16/FAT32 SD/MMC filesystems (provided ≤ 40 configuration words are used prior to copying user's code to system memory).
- Redundancy to support SD/MMC bad blocks, by searching for the BOOT signature in up to 24 blocks, and trying the next block if the BOOT signature is not found, or if a read CRC error is found.

#### 4.6.1.3 SD/MMC card data structure

The SD/MMC card should contain the initialization code length in bytes, source address in the SD/MMC card, destination address in the target memory device, execution starting address, and multiple configuration words with pairs of target address and its respective data.

The figure below shows the required SD/MMC card data structure.



Figure 4-8. SD/MMC card data structure

The table below describes the SD/MCC card data structure.

Table 4-39. SD/MMC card data structure

| Address   | Data bits [0-31]                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00-0x3F | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0x40-0x43 | BOOT signature                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | This location should contain the value 0x424F_4F54, which is the ascii code for BOOT. The boot loader code will search for this signature. If the value in this location doesn't match the BOOT signature, it means that the SD/MMC card doesn't contain a valid user code. In such case the boot loader code will disable the eSDHC and will issue a hardware reset request of the SoC by setting RSTCR[HRESET_REQ]. |
| 0x44-0x47 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x48-0x4B | User's code length                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | Number of bytes in the user's code to be copied. This must be a multiple of the SD/MMC card's block size (and the user's code zero-padded if necessary to achieve that length).                                                                                                                                                                                                                                       |
|           | User's code length ≤ 2 GBytes.                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x4C-0x4F | Reserved                                                                                                                                                                                                                                                                                                                                                                                                              |

Table continues on the next page...

Table 4-39. SD/MMC card data structure (continued)

| Address          | Data bits [0-31]                                                                                                                                                                                                                                                                        |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x50-0x53        | Source Address. Contains the starting address of the user's code as an offset from the SD/MMC card starting address.                                                                                                                                                                    |
|                  | In Standard Capacity SD/MMC Cards, the 32-bit Source Address specifies the memory address in byte address format. This must be a multiple of the SD/MMC card's block size.                                                                                                              |
|                  | In High Capacity SD Cards (> 2 GBytes), the 32-bit Source Address specifies the memory address in byte address format as well. However, it must be a multiple of block length, which is fixed to 512 bytes as stated in the SD High Capacity specification.                             |
| 0x54-0x57        | Reserved                                                                                                                                                                                                                                                                                |
| 0x58-0x5B        | Target Address                                                                                                                                                                                                                                                                          |
|                  | Contains the target address in the system's local memory address space in which the user's code will be copied to. This is a 32-bit effective address. The core is configured in such a way that the 36-bit real address is equal to this (with 4 most significant bits zero).          |
| 0x5C-0x5F        | Reserved                                                                                                                                                                                                                                                                                |
| 0x60-0x63        | Execution Starting Address                                                                                                                                                                                                                                                              |
|                  | Contains the jump address in the system's local memory address space into the user's code first instruction to be executed. This is a 32-bit effective address. The core is configured in such a way that the 36-bit real address is equal to this (with 4 most significant bits zero). |
| 0x64-0x67        | Reserved                                                                                                                                                                                                                                                                                |
| 0x68-0x6B        | N. Number of Config Address/Data pairs.                                                                                                                                                                                                                                                 |
|                  | Must be 1≤ N≤ 1024 (but is recommended to be as small as possible).                                                                                                                                                                                                                     |
| 0x6C-0x7F        | Reserved.                                                                                                                                                                                                                                                                               |
| 0x80-0x83        | Config Address 1                                                                                                                                                                                                                                                                        |
| 0x84-0x87        | Config Data 1                                                                                                                                                                                                                                                                           |
| 0x88-0x8B        | Config Address 2                                                                                                                                                                                                                                                                        |
| 0x8C-0x8F        | Config Data 2                                                                                                                                                                                                                                                                           |
|                  |                                                                                                                                                                                                                                                                                         |
| 0x80 + 8x(N-1)   | Config Address N <sup>1</sup>                                                                                                                                                                                                                                                           |
| 0x80 + 8x(N-1)+4 | Config Data N (final Config Data N optional)                                                                                                                                                                                                                                            |
|                  |                                                                                                                                                                                                                                                                                         |
|                  | User's code. Note that user's code must start on a 512-byte boundary.                                                                                                                                                                                                                   |

N ≤ 40 if compatibility with FAT12/FAT16/FAT32 filesystems is required. Refer to Notes on compatibility with FAT12/FAT16/FAT32 filesystems for details.

# 4.6.1.3.1 SD/MMC configuration words section

The configuration words section is comprised of Config Address and Config Data pairs of adjacent 32-bit fields.

These are typically used to configure the local access windows and the target memory controller's registers. They are therefore system-dependent, as they need to be aware of the type and configuration of memory in a particular system.

#### Initialization/applications information

The Config Address field has two modes that are selected by the least significant bit in the field (CNT). If the CNT bit is clear, then the 30 most significant bits are used to form the address pointer and the Config Data contains the data to be written to this address. If the CNT bit is set then the 30 most significant bits are used for control instruction. This flexible structure allows the user to configure any 4-byte aligned memory mapped register, perform control instructions, and specify the end of the configuration stage.

Note that it is illegal to change the content of the CCSRBAR by using this mechanism. Any attempt to do so will cause the boot process to hang.

The upper 4 most-significant address bits of the 36-bit address are always zero. Consequently the configuration words can only access memory in the lowest 4-GByte segment of memory. However, since by default CCSRBAR maps all memory mapped registers within the lowest 4-GByte segment of memory, and the user is prohibited from changing CCSRBAR with a configuration access, this is not an issue.

The Config Address structure is shown in the table below.

Table 4-40. Config address fields



Table 4-41 defines the Config Address bits when CNT = 0 (address mode), and Table 4-42 describes the Config Address bits when CNT = 1.

Table 4-41. Config address field description, CNT = 0

| Bits | Name    | Description                                                                                                                                                                                                                             |
|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-29 | Address | Address bits 0-29. The data in the Config Data field is copied by the e500 core to this address. The two least significant bits of the address (30:31) are always considered to be zero, as are the upper 4 bits of the 36-bit address. |
| 30   | -       | Reserved. Must be zero.                                                                                                                                                                                                                 |
| 31   | CNT     | Control. Select between Address mode and Control mode.                                                                                                                                                                                  |
|      |         | 0 Address mode                                                                                                                                                                                                                          |
|      |         | 1 Control mode                                                                                                                                                                                                                          |

Table 4-42. Config address field description, CNT = 1

| Bits | Name | Description                                                                                                                                                                                                                                                  |
|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | EC   | End Configuration. Indicates the end of the configuration stage. Valid only if bit CNT is set.                                                                                                                                                               |
|      |      | 0 Not the last Config Address field.                                                                                                                                                                                                                         |
|      |      | 1 The Last Config Address field. The e500 core will stop the configuration stage and start to copy the user's code.                                                                                                                                          |
|      |      | This must be set for Config Address Word N, and not be set for Config Address words prior to Config Address Word N.                                                                                                                                          |
| 1    | DLY  | Delay. Instruct the e500 core to perform delay according to the number that is specified in the adjacent Config Data field. The adjacent Config Data field provides the delay measured in terms of the number of 8 CCB clocks. Valid only if bit CNT is set. |
|      |      | 0 No delay.                                                                                                                                                                                                                                                  |
|      |      | 1 Delay.                                                                                                                                                                                                                                                     |
| 2-30 | -    | Reserved. Must be zero.                                                                                                                                                                                                                                      |
| 31   | CNT  | Control. Select between Address mode and Control mode.                                                                                                                                                                                                       |
|      |      | (0 Address mode)                                                                                                                                                                                                                                             |
|      |      | 1 Control mode                                                                                                                                                                                                                                               |
|      |      | When CNT = 1, bits 0-29 select the control instruction. Only one bit in the range of bits 0-29 can be set at any specific control instruction. A control instruction with bits 0-29 all cleared is also illegal.                                             |

### 4.6.1.3.2 Notes on compatibility with FAT12/FAT16/FAT32 filesystems

Depending upon application, compatibility may be desired between the SD/MMC Card data structure defined here and the FAT12, FAT16 or FAT32 filesystems (documented in SD Card Specifications Part 2 - File System Specification v2.0, among other places).

This compatibility is possible, but imposes a limit on the number of Configuration Words that can be parsed by the processor prior to fetching the user's code. Compatibility is achieved by ensuring that the entire data structure of Control Words and Configuration Words is contained within the first 446-byte (0x1BE) Master Boot Record code area of the filesystem.

Given that Configuration Words start at address 0x80, and all Configuration Words (except the last one with EC = 1 to end the configuration) occupy 8 bytes per Configuration Address/Data pair, this imposes the limit of a maximum of 40 Configuration Address words. More Configuration Words can be used in applications for which compatibility with the FAT Master Boot Record is not required. If exactly 40 Configuration Address words are used and FAT12/FAT16/FAT32 compatibility is required, then the final Configuration Data word must be omitted to ensure that the data structure fits in less than 446 bytes.

#### Initialization/applications information

Note that FAT12, FAT16 and FAT32 standards impose additional requirements on the data structures that must be present on the SD/MMC card, such as Partition Tables and a fixed Signature Word at the end of the Master Boot Record. These features are not interpreted or required by the eSDHC boot process, and are outside the scope of this document.

Furthermore, FAT12 and FAT16 define a boot sector with defined fields in the first 0x36 addressable bytes (which does not conflict with the SD/MMC Card Data Structure for boot from SD/MMC defined in this document). Therefore FAT12 and FAT16 filesystems are completely compatible with the defined data structure, even if they also contain a FAT boot sector. However, FAT32 defines a boot sector with defined fields in the first 0x52 addressable bytes. Therefore, FAT32 filesystem compatibility is only possible if used in a system in which this boot sector information is not required.

Also note that the user code is copied from one sequential area of SD/MMC card memory space specified by the Source Address. The boot ROM software does not look for or parse any File Allocation Table, and furthermore, the boot ROM software assumes that the User Code is in one contiguous range of memory addresses.

# 4.6.1.4 eSDHC controller initial configuration

The eSDHC controller configuration is used by the boot ROM software. After the boot from eSDHC has finished, the user can change this configuration for other uses of the eSDHC interface.

The boot ROM software also changes some of this configuration automatically depending upon the features supported by the SD/MMC card that is connected.

The eSDHC controller is initially configured to operate in the following configuration:

- Address Invariant Mode (eSDHC.PROTCTL[EMODE] = 10)
- SDHC\_DAT[3] does not monitor card insertion. The SDHC\_CD\_B pin is used for card detect (eSDHC.PROTCTL[D3CD] = 0 and Global\_Utilities.PMUXCR[SDHC\_CD] = 1).
- 1-bit Mode (eSDHC.PROTCTL[DTW] = 00)
- SDCLK at 400 kHz or below, but higher than 100 kHz (for platform frequency up to 400 MHz, and therefore eSDHC base clock frequency up to 200 MHz). This is done with eSDHC.SYSCTL[SDCLKFS] = 0x20 and eSDHC.SYSCTL[DVS] = 0xC, for a divisor of 832.
- There must be precisely one device connected on the eSDHC bus (and this device must be inserted prior to boot). Multiple MMC devices sharing the one bus are not supported.

- The bus operates in push-pull mode (device pads drive both logic "0" and logic "1" as appropriate). If an MMC card is to be connected, then weak external pull-ups are required on the SDHC\_CMD and SDHC\_DAT[] pins in order to interface with the MMC open-drain mode during initialization.
- The eSDHC DMA engine is not used for Control or Configuration Word accesses; instead, all eSDHC data transfers are initiated by the processor core polling eSDHC.PRSSTAT[BRR] and accessing data through the DATPORT register (XFERTYP[DMAEN] = 0). The eSDHC DMA engine is used for user code accesses.

### 4.6.1.5 eSDHC controller boot sequence

The code in the eSDHC Boot ROM configuration performs the following sequence of events:

- 1. The eSDHC controller is configured as per eSDHC controller initial configuration.
- 2. Card-detect.
- 3. The SD/MMC card is reset.
- 4. SD/MMC card voltage validation is performed.
- 5. SD/MMC card identification.
- 6. With CMD9, the CSD (Card-Specific Data) register of the SD/MMC card is read.
- 7. Based on the values returned from the SD/MMC card's CSD register, the eSDHC's registers are updated to reflect the maximum clock frequency jointly supported by the eSDHC controller, and the SD/MMC card connected to it.
- 8. The eSDHC begins reading the SD/MMC data structure from the card.
- 9. The eSDHC begins fetching the User Code from the card.
- 10. If either the BOOT signature is not found at memory offset 0x40, or if when reading the Control and Configuration Words or the User's Code a read CRC error is detected, then it may be due to a bad block on the SD/MMC memory card. To counteract this and provide error resilience, if this occurs the eSDHC returns to step 8, fetching data from an address 0x200 greater than the previously fetched address. For example, if there have been *i* failed attempts, then on the following try the BOOT signature is checked at offset 0x40 + i x 0x200. If this sequence fails 24 times, the system boot is deemed to have failed.
- 11. The processor core waits until the User Code DMA transfer is complete.
- 12. The processor core jumps to the Execution Starting Address to begin execution of the user's code.

### 4.6.1.6 eSDHC boot error handling

If at any stage the boot loader code detects an error and cannot continue, it will disable the eSDHC and will issue a hardware reset request of the SoC by setting RSTCR[HRESET\_REQ].

This may occur in any of the following scenarios:

- BOOT signature not found at offset 0x40 or CRC error on any of the data read by the eSDHC 24 times.
- Timeout while waiting for the SD/MMC card to respond at any stage.
- No card inserted.
- Incorrect type of card inserted that is not supported for boot (such as CE-ATA).
- There is no common protocol, voltage or frequency mutually supported by the SD/MMC card and the eSDHC.
- The eSDHC reads as far as the source address (specified by the control word of the SD/MMC data structure) without seeing a EC = 1 configuration word.

The boot loader code supports redundancy, which allows boot to succeed even in the presence of SD/MMC bad blocks. It does this by searching for the BOOT signature in up to 24 locations, and trying the next block if the BOOT signature is not found, or if a read CRC error is found. Each location tried is at a fixed offset of 512 bytes (0x200) from the previous (unsuccessful) offset, irrespective of the actual block size of the SD/MMC card.

For reference, the figure below shows an example SD/MMC memory card data structure that can be used for maximum SD/MMC card data redundancy.

Note that if  $0x40 + 8 \times (N - 1) + 4 \ge 0x200$  (where N is the number of configuration words), then care needs to be taken to ensure that the configuration words at  $0x40 + i \times 0x200$  (for all  $2 \le i \le 24$ ) must not contain the BOOT signature. This ensures that the boot loader code does not mistakenly detect a BOOT signature. This also reduces the number of copies of boot code that can be used on one device.

Each copy of the control/configuration words would generally be identical except for the pointer to the source address (offset 0x50) of the SD/MMC card, which may be different for each copy. If the user's code section is sufficiently large that 24 copies of it do not fit in the capacity of the SD/MMC card (or if the SD/MMC card capacity must also be utilized for functional features other than system boot), then it may still be desirable to still support up to 24 copies of the control/configuration words, but only have them reference a limited number of user's code sections.



**Note:** User's code must begin on 512-byte boundary and its length must be a multiple of 512 bytes.

Figure 4-9. SD/MMC card data structure for maximum redundancy

## 4.6.2 eSPI boot ROM

This section explains how to boot from eSPI.

It discusses the following:

- eSPI boot overview
- Features
- EEPROM data structure
- eSPI controller configuration

#### 4.6.2.1 eSPI boot overview

This device is capable of loading initialization code from a memory device that is connected to the eSPI controller interface.

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Initialization/applications information

This device can be either an EEPROM or a serial flash with an eSPI-compatible interface. The term EEPROM will be used when referring to the memory device.

The eSPI controller supports RapidS full clock cycle operation and Winbond dual output read serial interface, but these modes are not enabled for boot by the on-chip ROM.

Boot from eSPI is supported by the device using an on-chip ROM which contains the basic eSPI device driver and the code to perform block copy from eSPI EPROM to any target memory. Selecting on-chip ROM in boot ROM location, see Table 4-12, causes the e500 CPU to fetch data from the on-chip ROM. The on-chip ROM is selected by configuring the POR config pins *cfg\_rom\_loc[0:3]*.

After the device has completed the reset sequence, if the ROM location selects the on-chip ROM eSPI Boot configuration, the e500 core starts to execute code from the internal on-chip ROM. The e500 core configures the eSPI controller, enabling it to communicate with the external EEPROM. The EEPROM should contain a specific data structure with control words, device configuration information and initialization code. The on-chip ROM boot code uses the information from the EEPROM content to configure the device, and to copy the initialization code to a target memory device (for example, the DDR) through the eSPI interface. After all the code has been copied, the e500 core starts to execute the code from the target memory device.

There are several different ways a user may utilize the eSPI boot feature. The simplest is for the on-chip ROM to copy an entire operating system boot image into system memory, and then jump to it to begin execution. However, this may be many megabytes and in some situations may sub-optimal.

A more advanced option is for the on-chip ROM to only copy a small user-customised subroutine, which configures the eSPI in an optimal way. The user-customised subroutine then copies the rest of the boot code potentially much faster than the on-chip ROM software can achieve. For example, the user-customised subroutine may utilize Atmel RapidS or Winbond dual output eSPI modes.

#### **4.6.2.2 Features**

The main features are as follows:

- Provides mechanism to load initialization code from external eSPI EEPROM
- Simple data structure in eSPI EEPROM
- BOOT signature will be checked to validate that the EEPROM contains valid code
- Supports variable code length in EEPROM
- Flexible target memory device
- Supports target memory configuration controlled by the user

- Supports standard eSPI interface EEPROMs with read instruction code 0x03 followed by a 2-byte address (16-bit addressable EEPROMs) or 3-byte address (24-bit addressable EEPROMs).
- Initial setting will generate a serial clock below 5 MHz; the control word will allow for user modification of clock frequency.

#### 4.6.2.3 EEPROM data structure

The EEPROM should contain the initialization code length in bytes, source address in the eSPI EEPROM, destination address in the target memory device, execution starting address, and multiple configuration words with pairs of target address and its respective data.

The figure below shows the required eSPI EEPROM data structure.



Figure 4-10. eSPI EEPROM data structure

The table below describes the eSPI EEPROM data structure.

Table 4-43. eSPI EEPROM data structure

| Address   | Data bits [0-31]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00-0x3F | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x40-0x43 | BOOT signature. This location should contain the value 0x424F0_4F54, which is the ASCII code for BOOT. The eSPI loader code will search for this signature, initially in 24-bit addressable mode. If the value in this location doesn't match the BOOT signature, then the EEPROM is accessed again, but in 16-bit mode. If the value in this location still does not match the BOOT signature, it means that the eSPI device doesn't contain a valid user code. In such case the eSPI loader code will disable the eSPI and will issue a hardware reset request of the SoC by setting RSTCR[HRESET_REQ]. |

Table continues on the next page...

Table 4-43. eSPI EEPROM data structure (continued)

| Address            | Data bits [0-31]                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x44-0x47          | Reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 0x48-0x4B          | User's code length. Number of bytes in the user's code to be copied.                                                                                                                                                                                                                                                                                                      |
|                    | Must be a multiple of 4.                                                                                                                                                                                                                                                                                                                                                  |
|                    | 4 ≤ User's code length ≤ 2 Gbytes.                                                                                                                                                                                                                                                                                                                                        |
| 0x4C-0x4F          | Reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 0x50-0x53          | Source Address. Contains the starting address of the user's code as an offset from the EEPROM starting address. In 24-bit addressing mode, the 8 most significant bits of this should be written to as zero, because the EEPROM is accessed with a 3-byte (24-bit) address. In 16-bit addressing mode, the 16 most significant bits of this should be written to as zero. |
| 0x54-0x57          | Reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 0x58-0x5B          | Target Address. Contains the target address in the system's local memory address space in which the user's code will be copied to. This is a 32-bit effective address. The core is configured in such a way that the 36-bit real address is equal to this (with 4 most significant bits zero).                                                                            |
| 0x5C-0x5F          | Reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 0x60-0x63          | Execution Starting Address. Contains the jump address in the system's local memory address space into the user's code first instruction to be executed. This is a 32-bit effective address. The core is configured in such a way that the 36-bit real address is equal to this (with 4 most significant bits zero).                                                       |
| 0x64-0x67          | Reserved                                                                                                                                                                                                                                                                                                                                                                  |
| 0x68-0x6B          | N. Number of Config Address/Data pairs. Must be 1≤N≤1024 (but is recommended to be as small as possible).                                                                                                                                                                                                                                                                 |
| 0x6C-0x7F          | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |
| 0x80-0x83          | Config Address 1                                                                                                                                                                                                                                                                                                                                                          |
| 0x84-0x87          | Config Data 1                                                                                                                                                                                                                                                                                                                                                             |
| 0x88-0x8B          | Config Address 2                                                                                                                                                                                                                                                                                                                                                          |
| 0x8C-0x8F          | Config Data 2                                                                                                                                                                                                                                                                                                                                                             |
|                    |                                                                                                                                                                                                                                                                                                                                                                           |
| 0x80 + 8x(N-1)     | Config Address N                                                                                                                                                                                                                                                                                                                                                          |
| 0x80 + 8x(N-1) + 4 | Config Data N (Final Config Data N optional)                                                                                                                                                                                                                                                                                                                              |
|                    |                                                                                                                                                                                                                                                                                                                                                                           |
|                    | User's Code                                                                                                                                                                                                                                                                                                                                                               |

# 4.6.2.3.1 EEPROM configuration words section

The configuration words section is comprised of Config Address and Config Data pairs of adjacent 32-bit fields.

These are typically used to configure the local access windows and the target memory controller's registers. They are therefore system-dependent, as they need to be aware of the type and configuration of memory in a particular system.

The config address field has two modes that are selected by the least significant bit in the field (CNT). If the CNT bit is clear, then the 30 most significant bits are used to form the address pointer and the Config Data contains the data to be written to this address. If the CNT bit is set then the 30 most significant bits are used for control instruction. This flexible structure allows the user to configure any 4-byte aligned memory mapped register, perform control instructions, and specify the end of the configuration stage.

Note that it is illegal to change the content of the CCSRBAR by using this mechanism. Any attempt to do so will cause the boot process to hang.

The upper 4 most-significant address bits of the 36-bit address are always zero. Consequently the configuration words can only access memory in the lowest 4-GByte segment of memory. However, since by default CCSRBAR maps all memory mapped registers within the lowest 4-GByte segment of memory, and the user is prohibited from changing CCSRBAR with a configuration access, this is not an issue.

The Config Address structure is shown in the table below.

2 3 30 31 С С Address Ν Ν Т Τ 0 С С D C Ν С L Ν Т Т 1

Table 4-44. Config address fields

Table 4-45 shows the config address field description, CNT = 0.

| Bits | Name    | Description                                                                                                                                                                                                                             |
|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-29 | Address | Address bits 0-29. The data in the Config Data field is copied by the e500 core to this address. The two least significant bits of the address (30-31) are always considered to be zero, as are the upper 4 bits of the 36-bit address. |
| 30   | -       | Reserved. Must be zero.                                                                                                                                                                                                                 |
| 31   | CNT     | Control. Select between Address mode and Control mode.                                                                                                                                                                                  |
|      |         | 0 Address mode                                                                                                                                                                                                                          |
|      |         | 1 Control mode                                                                                                                                                                                                                          |

Table 4-45. Config address field description, CNT = 0

Table 4-46 shows the Config Address field description, CNT = 1.

Table 4-46. Config address field description, CNT = 1

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | EC   | End Configuration. Indicates the end of the configuration stage. Valid only if bit CNT is set.                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | 0 Not the last Config Address field.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      |      | 1 The Last Config Address field. The e500 core will stop the configuration stage and start to copy the user's code.                                                                                                                                                                                                                                                                                                                                                                               |
|      |      | This must be set for Config Address Word N, and not be set for Config Address words prior to Config Address Word N.                                                                                                                                                                                                                                                                                                                                                                               |
| 1    | DLY  | Delay. Instruct the e500 core to perform delay according to the number that is specified in the adjacent Config Data field. The adjacent Config Data field provides the delay measured in terms of the number of 8 CCB clocks. Valid only if bit CNT is set.                                                                                                                                                                                                                                      |
|      |      | 0 No delay.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |      | 1 Delay.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2    | CF   | Change frequency. Instruct the e500 core to perform sequence of operations to setup the eSPI CS0 mode register with the frequency related (PM and DIV16) bits as defined by the user. The adjacent Config Data field will be written to the eSPI mode register. Software will use DIV16 and PM bits and mask all other bits such that they will not change. Software will perform the necessary steps which are required by the eSPI controller before and after changing the eSPI mode register. |
|      |      | This only takes effect after all of the Configuration and Control words have been read.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3-30 | -    | Reserved. Must be zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31   | CNT  | Control. Select between Address mode and Control mode.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |      | 0 Address mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | 1 Control mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | NOTE: When CNT = 1, bits 0-29 select the control instruction. Only one bit in the range of bits 0-29 can be set at any specific control instruction. A control instruction with bits 0-29 all cleared is also illegal.                                                                                                                                                                                                                                                                            |

## 4.6.2.4 eSPI controller configuration

The eSPI controller configuration is used by the eSPI boot ROM software.

After the boot from eSPI has finished, the user can change this configuration for other uses of the eSPI interface.

The eSPI controller is configured to operate in master mode. The eSPI chip select 0 (SPI\_CS[0]) must be connected to the EEPROM CS\_B and selectively enables the EEPROM.

The figure below shows the external signal connection.



Figure 4-11. External signal connection

The eSPI controller is configured by the on-chip ROM code. The controller is configured as follows:

- Data is shifted out data on SPIMOSI during the falling edge of SPICLK. It samples data in from SPIMISO during the rising edge of SPICLK.
- The clock is low when the line is idle.
- It uses 8-bit length characters.
- The platform clock is divided by 256. For example, when the platform clock is configured to 533 MHz, the SPICLK will run at 2.08 MHz. (Note that frequency setting can be changed by using the CF control word, as explained in the EEPROM configuration words section.)
- The MSB is sent and received first.

For default eSPI CS0 mode register (SPMODE0) configuration, see eSPI CS0 mode register (ESPI\_SPMODE0). During ROM boot, the ROM code needs to change the reset value of eSPI CS0 mode register to 0x3117\_2210.

The ROM code will initially use the eSPI controller to generate standard read instruction code 0x03 followed by a 3-byte address for every non-sequential read operation (reading from a location which is not sequential to the last byte read). For sequential read operation, toggling the eSPI clock will cause the eSPI EEPROM to present the content of the next address location. The serial EEPROM must have an eSPI compatible interface with read instruction code 0x03 followed by a 2 or 3-byte address.

#### Initialization/applications information

16-bit addressable EEPROM memories are supported and detected automatically by the boot code. This is accomplished by the boot code trying 16-bit mode if it fails to find the "BOOT" signature when in 24-bit mode.

The figure below shows the read instruction timing diagram for normal (not Atmel RapidS or Winbond Dual Output) modes of operation with a 24-bit addressable eSPI memory. With 16-bit addressable eSPI memories, only a 16-bit address is transmitted, and valid data is received from the EEPROM on the 24th SPICLK cycle rather than the 32nd SPICLK cycle for 24-bit addressable memories.



Figure 4-12. Read instruction timing diagram (24-bit addressable eSPI memory)

## 4.6.3 Default e500 addressing during system boot

During boot from the on-chip ROM (for boot targets of either eSPI or SD/MMC), the user specifies 32-bit addresses for several fields (Target Address for copying the user's code, and the Execution Starting Address).

This section describes how these 32-bit effective addresses are translated into 36-bit real addresses and the associated address translation and mapping.

The L2 cache remains disabled as per its power-on-reset state. The e500 Level 1 and Level 2 MMU configuration is left as per defaults, with the exception that the following TLB1 Entry 1 is also created (in addition to the default TLB1 Entry 0 4 kByte page at 0x0\_FFFF\_Fnnnn):

• V = 1 (valid)

- TS = 0 (address space 0)
- TID = 0x00 (global)
- EPN[32:51] = 0x00000
- RPN[32:51] = 0x00000
- SIZE[0:3] = 1011 (4 GByte)
- SX/SR/SW = 111 (Full supervisor mode access allowed)
- UX/UR/UW = 000 (No user mode access allowed)
- WIMGE = 01110 (Cache-inhibited, Memory coherency required, Guarded)
- X0-X1 = 00
- U0-U3=0
- IPROT = 1 (Page is protected from invalidation)

This configuration results in a 32-bit byte address with a 0-bit effective page number. Therefore the 36-bit real address is equal to the 32-bit effective address, with the 4 MSbits of the 36-bit real address equal to 0.

The on-chip ROM code does not setup any Local Access Windows. Access to CCSR address space (and therefore by extension, also access to the on-chip ROM) does not require a Local Access Window. It is the user's responsibility to setup a local access window through a Control Word address/data pair for the desired Target Address and Execution Starting Address (which will typically be in either DDR or Local Bus memory space).

Note that any such local access window configured at this time must have the 4 MSbits of the address equal to 0. This is due to the 32-bit addressing enabled by the e500 MMUs as described above.

The user can reconfigure the system in the user code portion based on system requirements.

Initialization/applications information

# **Chapter 5 e500 Core Integration Details**

e500 core integration and the core complex bus (CCB) describes hardware aspects of that integration and provides links to chapters that discuss functionality in which core and SoC operations interact.

### 5.1 Overview

This chapter describes how the core is integrated into the SoC.

e500 core integration and the core complex bus (CCB) describes hardware aspects of that integration and provides links to chapters that discuss functionality in which core and SoC operations interact. Such topics include reset, power management, interrupt management, and debug.

This chapter also lists SoC-specific details of the core's programming model. For example, the e500 programming model defines the processor version register (PVR), system version register (SVR), and special-purpose registers (SPRs) that respectively identify the version and revision of the core and of the integrated device. These values are provided in Summary of core integration details, and additional links are provided to other chapters that provide a context for a discussion of these registers. The section Register model integration details in Table 5-1 describes a few aspects of the core programming model that has SoC-specific behavior that cannot be fully understood by reading the e500 Reference Manual alone.

General information about e500 core functionality can be found in this chapter and in the following documentation:

• The *PowerPC e500 Core Family Reference Manual* (referred to here as the *e500 Reference Manual*) provides detailed information about the functions and features of the core. In particular, it describes details about how architecture-defined features are implemented.

#### e500 core block diagram

- The "e500 Core Complex Bus (CCB) and System Integration" chapter in the *e500 Reference Manual* describes core-to-SoC integration issues from the perspective of the e500 core.
- The EREF: A Programmer's Reference Manual for Freescale Embedded Processors (Including the e200 and e500 Families) describes in detail features defined by the Power ISA and Freescale EIS (referred to generically as the architecture). Unless otherwise stated in the e500 Reference Manual, e500 features are implemented as defined by the architecture and described in the EREF.
- How the integrated device implements e500 core features, including specific registers and register fields, is summarized in Summary of core integration details.

# 5.2 e500 core block diagram

The chip core complex block diagram shows how the functional units operate independently and in parallel.

Note that this is a conceptual diagram that does not attempt to show how these features are physically implemented.



P1021 CarlO Integrated Processor Beference Manual Beyan 01/2013

# 5.3 e500 core integration and the core complex bus (CCB)

The CCB is the hardware interface between the core and the SoC. With a few exceptions, the user cannot access these internal signals directly.

This figure shows a selection of CCB signals that are discussed in various places in this manual and in the core reference manual, because understanding how they work helps to understand the functionality of this chip.



Figure 5-2. e500 core integration

Aspects of the e500 chip integration are summarized as follows:

#### • Reset

The core directs and coordinates device's hard and soft resets and the power-on reset (POR) sequence, power-on reset configuration, and initialization. Core integration of the reset signals shown in Figure 5-2 is described in the chapters Reset, Clocking, and Initialization and Global Utilities.

### • Clocking and timers

Integration details of the CCB clocking signals are described in Reset, Clocking, and Initialization. Additional details regarding the timer configuration are described in Summary of core integration details.

### Cache and memory-mapped SRAM

The e500 cache implementation interacts with the SoC's L2 cache. In particular, the core implements a number of instructions that interact with the L2 cache implementation, which are described in the *e500 Reference Manual* and in the *EREF*. L2 Look-Aside Cache/SRAM describes the SoC's L2 cache. Figure 5-2 shows the e500 signals that interface with the L2 cache.

### • e500 coherency module (ECM)

The ECM, described in e500 Coherency Module, facilitates communication between the core, the L2 cache, and the other blocks that comprise the coherent memory domain of the SoC.

The ECM provides a mechanism for I/O-initiated transactions to snoop the core complex bus (CCB) of the core to maintain coherency across cacheable local memory. It also provides a flexible, easily expandable switch-type structure for coreand I/O-initiated transactions to be routed (dispatched) to target modules on the device. The CCB is described in the "Core Complex Bus (CCB) and System Integration" chapter of the *e500 Reference Manual*.

## • Interrupts

The e500 core handles the hardware interrupts that are generated from SoC peripheral logic, typically by error conditions encountered from within blocks on the integrated device. Programmable Interrupt Controller (PIC) describes the programmable interrupt controller, which prioritizes interrupt requests to the core. Figure 5-2 shows the e500 signals that interface with the PIC.

## • Power management

The core's HID0[NAP, DOZE,SLEEP] can be used to assert *nap*, *doze*, and *sleep* output signals to initiate power-saving modes at the integrated device level. Figure 5-2 shows the e500 signals, which interact with the SoC level power management logic described in Global Utilities.

## • System debug

#### Summary of core integration details

The architecture defines many features for software and hardware debug that interact with the SoC. Debug Features and Watchpoint Facility describes the debug features and watchpoint monitor. Figure 5-2 shows the e500 signals that interface with the debug block. The core reference manual describes how the architecture-defined debug resources are implemented on the e500 core.

The "Core Complex Bus (CCB) and System Integration" chapter of the core reference manual describes the signals that are shown in the figure above and other aspects of core integration.

# 5.4 Summary of core integration details

The summary of core integration details is organized into two sections: General feature integration details and register model integration details.

This table summarizes details of the QorIQ -specific implementation of the core, which is organized into the following sections:

- General feature integration details summarizes integration-specific details by functionality.
- Register model integration details summarizes how integration-specific details are reflected in the SoC's implementation of the core register model.

Table 5-1. Differences between the e500 core and the QorlQ core implementation

| Feature                                 | QorlQ implementation                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                         | General feature integration details                                                                                                                                                                                                                                                          |  |  |  |  |  |
| Cache protocol                          | The write-through L2 cache implemented on the SoC does not support MESI cache protocol.                                                                                                                                                                                                      |  |  |  |  |  |
| Clocking                                | Internal clock multipliers ranging from 1 to 8 times the bus clock, including integer and half-mode multipliers. The integrated device supports multipliers of 2, 2.5, 3, and 3.5. See the table entry, HID1 Implementation, for further details.                                            |  |  |  |  |  |
| R1 and R2 data bus parity               | R1 and R2 data bus parity are disabled on QorlQ devices. HID1[R1DPE,R2DPE] are reserved.                                                                                                                                                                                                     |  |  |  |  |  |
| Dynamic bus snooping                    | The QorlQ devices do not perform dynamic bus snooping as described here. That is, when the e500 core is in core-stopped state (which is the state of the core when the QorlQ device is in either the nap or sleep state), the core is not awakened to perform snoops on global transactions. |  |  |  |  |  |
| Device specific definition for TCR[WRC] | QorlQ devices define values for 00, 01, 10, and 11, as described in Register Model Integration Details in this table.                                                                                                                                                                        |  |  |  |  |  |

Table 5-1. Differences between the e500 core and the QorlQ core implementation (continued)

| Feature                           | QorlQ implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPE and floating-point categories | The SPE (which includes the embedded vector and scalar floating-point instructions) will not be implemented in the next generation of QorlQ devices. Freescale Semiconductor strongly recommends that use of these instructions be confined to libraries and device drivers. Customer software that uses these instructions at the assembly level or that uses SPE or floating-point intrinsics will require rewriting for upward compatibility with next generation QorlQ devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                   | The e500v2 core implements SPE double-precision floating-point instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                   | Freescale Semiconductor offers a libcfsl_e500 library that uses SPE instructions. Freescale Semiconductor will also provide future libraries to support next generation QorlQ devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                   | Note that in the Power ISA, MSR[SPE] and ESR[SPE] are renamed to MSR[SPV] and ESR[SPV].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                   | Register Model Integration Details                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| HID0 implementation               | SEL_TBCLK. Selects time base clock. If this bit is set and the time base is enabled, the time base is based on the TBCLK input, which on the QorlQ devices is RTC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| HID1                              | HID1[PLL_CFG] is implemented as two subfields:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Implementation                    | PLL_MODE (HID1[32-33]):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                   | Read-only for integrated devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                   | 1 1 Fixed value for this device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                   | PLL_CFG, (HID1[34-39]): The following clock ratios are supported:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                   | 0001_00 Ratio of 2:1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                   | 0001_01 Ratio of 5:2 (2.5:1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                   | 0001_10 Ratio of 3:1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                   | 0001_11 Ratio of 7:2 (3.5:1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                   | NEXEN, R1DPE, R2DPE, MPXTT, MSHARS, SSHAR, ATS, and MID are not implemented.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                   | On QorlQ devices, ABE must be set to ensure that cache and TLB management instructions operate properly on the L2 cache.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                   | HID1[RFXE].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                   | If RFXE is 0, conditions that cause the assertion of <i>core_fault_in_B</i> cannot directly cause the e500 to generate a machine check; however, QorlQ devices must be configured to detect and enable such conditions. The following bullets describe how error bits should be configured:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                   | <ul> <li>ECM mapping errors: EEER[LAEE] must be set. See ECM error enable register (ECM_EEER).</li> <li>L2 multiple-bit ECC errors: L2ERRDIS[MBECCDIS] must be cleared to ensure that error can be detected. L2ERRINTEN[MBECCINTEN] must be set. See L2 error registers.</li> <li>DDR multiple-bit ECC errors: ERR_DISABLE[MBED] must be zero and ERR_INT_EN[MBEE] must be set and DDR_SDRAM_CFG[ECC_EN] must be one to ensure that an interrupt is generated. See DDR memory map/register definition.</li> <li>PCI. The appropriate parity detect and master-abort bits in ERR_DR must be cleared and the corresponding enable bits in ERR_EN must be set to ensure that an interrupt is generated.</li> <li>Local bus controller parity errors. LTEDR[PARD] must be cleared and LTEIR[PARI] must be set to ensure that an parity errors can generate an interrupt. See Transfer error interrupt register (eLBC_LTEIR), and Transfer error attributes register (eLBC_LTEATR).</li> </ul> |
| PIR value                         | The PIR value corresponds to the core number on multicore QorlQ devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PVR value                         | The PVR reset value is 0x80nn_nnnn. See Table 5-2 for specific values.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                   | PVR[VERSION] = 0x80nn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                   | PVR[REVISION] = 0xnnnn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Summary of core integration details

Table 5-1. Differences between the e500 core and the QorlQ core implementation (continued)

| Feature           | QorlQ implementation                                                                                                                                                                                                                                                          |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| SVR value         | lue The SVR reset value is 0x80nn_nnnn. See Table 5-2 for specific values.                                                                                                                                                                                                    |  |  |  |
| TCR (timer        | TCR[WRC] is defined more specifically for the implementation of the core in the integrated device.                                                                                                                                                                            |  |  |  |
| control register) | Watchdog timer reset control. This value is written into TSR[WRS] when a watchdog event occurs. WRC may be set by software but cannot be cleared by software, except by a software-induced reset. Once written to a non-zero value, WRC may no longer be altered by software. |  |  |  |
|                   | 00 No watchdog timer reset will occur                                                                                                                                                                                                                                         |  |  |  |
|                   | 01 Second timeout generates machine check                                                                                                                                                                                                                                     |  |  |  |
|                   | 10 Second timeout generates HRESET_REQ output externally                                                                                                                                                                                                                      |  |  |  |
|                   | 11 Second timeout automatically resets the given processor core                                                                                                                                                                                                               |  |  |  |

# 5.4.1 Processor version register (PVR) and system version register (SVR)

The table below matches the revision codes in the processor version register (PVR) with the core revision and the SoC revision; it includes a cross-reference to the section in global utilities that contains the corresponding SVR values. Note that the SVR and PVR can be accessed both as SPRs through the e500 core (see the e500 Reference Manual) and as memory-mapped registers defined by the integrated device.

Table 5-2. Device revision level cross-reference

|   | SoC revision | Core revision | Processor version register (PVR) | System version register (SVR)         |
|---|--------------|---------------|----------------------------------|---------------------------------------|
| Г | 1.0          | 5.0           | 0x8021_2050                      | Processor version register (GUTS_PVR) |

# Chapter 6 L2 Look-Aside Cache/SRAM

This chapter describes the organization of the on-chip L2/SRAM, cache coherency rules, cache line replacement algorithm, cache control instructions, and various cache operations.

## 6.1 Introduction

This chapter describes the organization of the on-chip L2/SRAM, cache coherency rules, cache line replacement algorithm, cache control instructions, and various cache operations.

It also describes the interaction between the L2/SRAM and the e500 core complex.

## 6.2 L2 cache overview

The integrated 256 KB L2 cache is organized as 1024 eight-way sets of 32-byte cache lines based on 36-bit physical addresses.

This figure shows the L2 cache/SRAM configuration.



Figure 6-1. L2 cache/SRAM configuration

The SRAM can be configured with memory-mapped registers as externally accessible memory-mapped SRAM in addition to or instead of cache. The L2 cache can operate in the following modes, described in L2 cache and SRAM organization:

- Full cache mode (256 KB cache).
- Full memory-mapped SRAM mode (256 KB SRAM mapped as a single 256 KB block or two 128 KB blocks)
- Partial SRAM and partial cache mode, in which 1/8, 1/4, or 1/2 the total on-chip memory can be allocated to 1 or 2 SRAM regions.

## 6.2.1 L2 cache and SRAM features

The L2 cache includes the following characteristics:

- Supports 36-bit address space
- Write-through, front-side cache
  - Front-side design provides easier cache access for the I/O masters, such as QE, Ethernet
  - Write-through design is more efficient on the processor bus for front-side caches
- Valid, locked, and stale states (no modified state)
- Two input data buses (64 and 128 bits wide) and one output data bus (128 bits wide)
- All accesses are fully pipelined and non-blocking (allows hits under misses)
- 256 -KB array organized as 1024 eight-way sets of 32-byte cache lines
- Eight-way set associativity with a pseudo-LRU (7-bit) replacement algorithm.
  - High level of associativity yields good performance even with many lines locked or used as SRAM regions

- I/O devices can store data into the cache in a process called 'stashing.'
  - Stashing is indicated for global I/O writes either by a transaction attribute or by a programmable memory range
  - Regions of the cache can be reserved exclusively for stashing to prevent pollution of processor cache regions.
- Processor L2 cache regions are configurable to allocate instructions, data, or both.
  - External masters can force data to be allocated into the cache through programmed memory ranges or special transaction types (stashing).
    - 1, 2, or 4 ways can be configured for stashing only
- Data ECC on 64-bit boundaries (single-error correction, double-error detection)
- Tag arrays use 21 tag bits and 1 tag parity bit per line.
- Multiple cache locking methods supported
  - Individual line locks are set and cleared using e500 cache locking APU instructions-Data Cache Block Touch and Lock Set (**dcbtls**), Data Cache Block Touch for Store and Lock Set (**dcbtstls**), and Instruction Cache Block Touch and Lock Set (**icbtls**).
  - A lock attribute can be attached to write operations.
  - Individual line locks are set and cleared through core-initiated instructions, by external reads or writes, or by accesses to programmed memory ranges defined in L2 cache external write address registers (L2CEWAR*n*).
  - The entire cache can be locked by setting configuration register appropriately.
- Lock clearing methods
  - Individual locks can be cleared by cache-locking APU instructions-Data Cache Block Lock Clear (**dcblc**) and Instruction Cache Block Lock Clear (**icblc**)-or by a snooped flush unless entire cache is locked.
  - Flash clearing of all instruction and/or data locks is done by writes to configuration registers.
  - An unlock attribute can be attached to a read instruction.
- Error injection modes supported for testing error handling

## SRAM features include the following:

- SRAM regions are created by configuring 1, 2, 4 or 8 ways of each set to be reserved for memory-mapped SRAM.
- Regions can reside at any location in the memory map aligned to the SRAM size.
- SRAM memory is byte addressable; for accesses of less than a cache line, ECC is updated using read-modify-write transactions.
- I/O devices access SRAM regions by marking transactions as snoopable (global).

Table 6-1 lists the possible L2 cache/SRAM configurations.

Table 6-1. Available L2 cache/SRAM configurations

| Cache  | Stash-only Region | SRAM Region 1 | SRAM Region 2 |
|--------|-------------------|---------------|---------------|
| 256 KB | -                 | -             | -             |
| 224 KB | -                 | 32 KB         | -             |
|        | 32 KB             | -             | -             |
| 192 KB | -                 | 64 KB         | -             |
|        |                   | 32 KB         | 32 KB         |
|        | 32 KB             | 32 KB         | -             |
|        | 64 KB             | -             | -             |
| 160 KB | 32 KB             | 64 KB         | -             |
|        |                   | 32 KB         | 32 KB         |
|        | 64 KB             | 32 KB         | -             |
| 128 KB | -                 | 128 KB        | -             |
|        |                   | 64 KB         | 64 KB         |
|        | 64 KB             | 64 KB         | -             |
|        |                   | 32 KB         | 32 KB         |
|        | 128 KB            | -             | -             |
| 96 KB  | 32 KB             | 128 KB        | -             |
|        |                   | 64 KB         | 64 KB         |
|        | 128 KB            | 32 KB         | -             |
| 64 KB  | 64 KB             | 128 KB        | -             |
|        |                   | 64 KB         | 64 KB         |
|        | 128 KB            | 64 KB         | -             |
|        |                   | 32 KB         | 32 KB         |
| -      | -                 | 256 KB        | -             |
|        |                   | 128 KB        | 128 KB        |
|        | 128 KB            | 128 KB        | -             |
|        |                   | 64 KB         | 64 KB         |

# 6.3 L2 cache and SRAM organization

The on-chip memory array has four banks, each containing 256 sets of eight cache blocks (or "ways"). Each block consists of 32 bytes of data and a tag.

This figure shows the organization of the cache.



Figure 6-2. Cache organization

# 6.3.1 Accessing the on-chip array as an L2 cache

This figure shows how physical address bits are used to access the L2 cache.



Figure 6-3. Physical address usage for L2 cache accesses

Physical address bits 21 -30 identify the bank and set of the tag and data. Physical address bits 0-20 are compared against the tags of all eight ways. A match of a valid tag selects a 32-byte block of data (or way) within the set. Physical address bits 31-35 identify the byte or bytes of data within the block.

## 6.3.2 Accessing the on-chip array as an SRAM

When all or part of the array is dedicated to memory mapped SRAM, individual ways of each set are reserved for that purpose.

SRAM accesses use physical address bits 18-20 in conjunction with the SRAM mode to select a way of the indexed set.

This figure shows the physical address usage for SRAM accesses.



Figure 6-4. Physical address usage for SRAM accesses

The mapping of address bits and SRAM mode to a way select is shown in this table. SRAM size is reflected in L2CTL[L2SIZ].

Table 6-2. Way selection for SRAM accesses

| Description                        | L2SRAM | L2SRBAR 0 Hit | L2SRBAR 1 Hit | Addr[18-20 ] | Way Select |
|------------------------------------|--------|---------------|---------------|--------------|------------|
| No SRAM                            | 000    | -             | -             | -            | -          |
| Entire Array is SRAM               | 001    | 1             | 0             | 000          | 0          |
| (single 256 KB SRAM if L2SIZ = 256 |        |               |               | 001          | 1          |
| (KB)                               |        |               |               | 010          | 2          |
|                                    |        |               |               | 011          | 3          |
|                                    |        |               |               | 100          | 4          |
|                                    |        |               |               | 101          | 5          |
|                                    |        |               |               | 110          | 6          |
|                                    |        |               |               | 111          | 7          |

Table 6-2. Way selection for SRAM accesses (continued)

| Description                           | L2SRAM | L2SRBAR 0 Hit | L2SRBAR 1 Hit | Addr[18-20 ] | Way Select |
|---------------------------------------|--------|---------------|---------------|--------------|------------|
| One-half of array is an SRAM          | 010    | 1             | 0             | x00          | 0          |
| (single 128 KB SRAM if L2SIZ = 256    |        |               |               | x01          | 1          |
| KB)                                   |        |               |               | x10          | 2          |
|                                       |        |               |               | x11          | 3          |
| Both halves of array are SRAM         | 011    | 1             | 0             | x00          | 0          |
| (two 128 KB SRAM if L2SIZ = 256 KB)   |        |               |               | x01          | 1          |
|                                       |        |               |               | x10          | 2          |
|                                       |        |               |               | x11          | 3          |
|                                       |        | 0             | 1             | x00          | 4          |
|                                       |        |               |               | x01          | 5          |
|                                       |        |               |               | x10          | 6          |
|                                       |        |               |               | x11          | 7          |
| One quarter of the array is SRAM      | 100    | 1             | 0             | xx0          | 0          |
| (single 64 KB SRAM if L2SIZ = 256 KB) |        |               |               | xx1          | 1          |
| Two quarters of the array are SRAMs   | 101    | 1             | 0             | xx0          | 0          |
| (single 64 KB SRAM if L2SIZ = 256 KB) |        |               |               | xx1          | 1          |
|                                       |        | 0             | 1             | xx0          | 2          |
|                                       |        |               |               | xx1          | 3          |
| One-eighth of the array is an SRAM    | 110    | 1             | 0             | -            | 0          |
| (single 32 KB SRAM if L2SIZ = 256 KB) |        |               |               |              |            |
| Two-eighths of the array are SRAM     | 111    | 1             | 0             | -            | 0          |
| (single 32 KB SRAM if L2SIZ = 256 KB) |        | 0             | 1             | -            | 1          |

## 6.3.3 Connection of the on-chip memory to the system

The e500 core connects to the L2 cache and the system interface through the high-speed core complex bus (CCB).

The e500 core and the L2 cache connect to the rest of the integrated device through the e500 coherency module (ECM). This figure shows the data connections of the e500 core and L2/SRAM. The e500 core can simultaneously read 128 bits of data from the L2/SRAM, read 64 bits of data from the system interface, and write 128 bits of data to the L2/SRAM and/or system interface.

The L2/SRAM can be accessed by the e500 core or the system interface through the ECM. The L2 cache does not initiate transactions. Figure 6-5 shows the data bus connections of the e500 core and L2/SRAM.



Figure 6-5. Data bus connection of CCB

This figure shows address connections of the e500 core and L2/SRAM.



Figure 6-6. Address bus connection of CCB

In SRAM mode, if a non-cache-line read or write transaction is not preceded by a cache-line write, an ECC error occurs; such a non-cache-line write transaction cannot be allocated in the L2.

# 6.4 L2 cache external write registers

The device supports allocating and locking L2 cache lines from external agents such as PCI. This functionality is called stashing.

Four sets of registers are provided to support this feature; each set has three registers that specify a programmed memory range that can be locked with a snoop write transaction. All three registers in a set must be configured in order to use an external write address.

#### L2 memory-mapped SRAM registers

These registers are the L2 cache external write address registers 0-3 (L2CEWAR*n*), the L2 cache external write address registers extended address 0-3 (L2CEWAREA*n*), and the L2 cache external write control registers 0-3 (L2CEWCR*n*). L2CEWAR*n* contain the lower 24 bits of the external write base address and L2CEWAREA*n* contain the upper 4 bits. The base address specified in the address registers must be naturally aligned to the window size in the corresponding control register.

Further details on the locations and fields of these registers are given in the following sections.

# 6.5 L2 memory-mapped SRAM registers

The L2 memory-mapped SRAM base address registers 0-1 (L2SRBAR*n*) and the L2 memory-mapped SRAM base address registers extended address 0-1 (L2SRBAREA*n*), control the memory-mapped SRAM mode functionality. Together, these two pairs of registers define memory blocks that can be mapped into the L2 cache.

Specified SRAM base addresses must be aligned to the size of the SRAM region. If L2CTL[L2SRAM] specifies one memory-mapped SRAM block, its base address must be written to the pair L2SRBAR0 and L2SRBAREA0; if it specifies two memory-mapped SRAM blocks, L2SRBAR0 and L2SRBAREA0 are used for the first SRAM block and L2SRBAR1 and L2SRBAREA1 are used for the second block.

## 6.6 L2 error registers

L2 error detection, reporting, and injection allow flexible handling of ECC and parity errors in the L2 data and tag arrays.

When the device detects an L2 error, the appropriate bit in the error detect register (L2ERRDET) is set. Error detection is disabled by setting the corresponding bit in the error disable register (L2ERRDIS).

The address and attributes of the first detected error are also saved in the error capture registers (L2ERRADDR, L2ERRATTR, L2CAPTDATAHI, L2CAPTDATALO, and L2CAPTACC). Subsequent errors set error bits in the error detection registers, but information is saved only for the first one. Error reporting (by generating an interrupt) is enabled by setting the corresponding bit in the error interrupt enable register (L2ERRINTEN). Note that the error detect bit is set regardless of the state of the interrupt enable bit. When an error is detected, if error detection is enabled the L2 cache/SRAM

always asserts an internal error signal with read data to prevent the L1 caches and architectural registers from being loaded with corrupt data. If error detection is disabled, the detected error bit is not set and no internal signal is asserted.

The L2 error detect register (L2ERRDET) is implemented as a bit-reset type register. Reading from this register occurs normally; however, write operations can clear but not set bits. A bit is cleared whenever the register is written and the data in the corresponding bit location is a 1. For example, to clear bit 6 and not affect any other bits in the register, the value 0x0200\_0000 is written to the register.

Note that in SRAM mode, if a non-cache-line read or write transaction is not preceded by a cache-line write, an ECC error occurs; such a non-cache-line write transaction cannot be allocated in the L2.

# 6.7 L2\_Cache memory map/register definition

The following table shows the memory map for the L2/SRAM registers.

#### L2\_Cache memory map

| Offset<br>address<br>(hex) | Register name                                                                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-----------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_0000                     | L2 control register (L2_Cache_L2CTL)                                              | 32                 | R/W    | 1000_0000h  | 6.7.1/206        |
| 2_0004                     | L2 cache way allocation for processors (L2_Cache_L2CWAP)                          | 32                 | R/W    | 0000_0000h  | 6.7.2/211        |
| 2_0010                     | L2 cache external write address register n (L2_Cache_L2CEWAR0)                    | 32                 | R/W    | 0000_0000h  | 6.7.3/213        |
| 2_0014                     | L2 cache external write address register extended address n (L2_Cache_L2CEWAREA0) | 32                 | R/W    | 0000_0000h  | 6.7.4/213        |
| 2_0018                     | L2 cache external write control register n (L2_Cache_L2CEWCR0)                    | 32                 | R/W    | 0000_0000h  | 6.7.5/214        |
| 2_0020                     | L2 cache external write address register n (L2_Cache_L2CEWAR1)                    | 32                 | R/W    | 0000_0000h  | 6.7.3/213        |
| 2_0024                     | L2 cache external write address register extended address n (L2_Cache_L2CEWAREA1) | 32                 | R/W    | 0000_0000h  | 6.7.4/213        |
| 2_0028                     | L2 cache external write control register n (L2_Cache_L2CEWCR1)                    | 32                 | R/W    | 0000_0000h  | 6.7.5/214        |
| 2_0030                     | L2 cache external write address register n (L2_Cache_L2CEWAR2)                    | 32                 | R/W    | 0000_0000h  | 6.7.3/213        |
| 2_0034                     | L2 cache external write address register extended address n (L2_Cache_L2CEWAREA2) | 32                 | R/W    | 0000_0000h  | 6.7.4/213        |

#### L2\_Cache memory map/register definition

## L2\_Cache memory map (continued)

| Offset address (hex) | Register name                                                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|--------------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_0038               | L2 cache external write control register n (L2_Cache_L2CEWCR2)                       | 32                 | R/W    | 0000_0000h  | 6.7.5/214        |
| 2_0040               | L2 cache external write address register n (L2_Cache_L2CEWAR3)                       | 32                 | R/W    | 0000_0000h  | 6.7.3/213        |
| 2_0044               | L2 cache external write address register extended address n (L2_Cache_L2CEWAREA3)    | 32                 | R/W    | 0000_0000h  | 6.7.4/213        |
| 2_0048               | L2 cache external write control register n (L2_Cache_L2CEWCR3)                       | 32                 | R/W    | 0000_0000h  | 6.7.5/214        |
| 2_0100               | L2 memory-mapped SRAM base address register n (L2_Cache_L2SRBAR0)                    | 32                 | R/W    | 0000_0000h  | 6.7.6/215        |
| 2_0104               | L2 memory-mapped SRAM base address register extended address n (L2_Cache_L2SRBAREA0) | 32                 | R/W    | 0000_0000h  | 6.7.7/216        |
| 2_0108               | L2 memory-mapped SRAM base address register n (L2_Cache_L2SRBAR1)                    | 32                 | R/W    | 0000_0000h  | 6.7.6/215        |
| 2_010C               | L2 memory-mapped SRAM base address register extended address n (L2_Cache_L2SRBAREA1) | 32                 | R/W    | 0000_0000h  | 6.7.7/216        |
| 2_0E00               | L2 error injection mask high register (L2_Cache_L2ERRINJHI)                          | 32                 | R/W    | 0000_0000h  | 6.7.8/217        |
| 2_0E04               | L2 error injection mask low register (L2_Cache_L2ERRINJLO)                           | 32                 | R/W    | 0000_0000h  | 6.7.9/218        |
| 2_0E08               | L2 error injection tag/ECC control register (L2_Cache_L2ERRINJCTL)                   | 32                 | R/W    | 0000_0000h  | 6.7.10/218       |
| 2_0E20               | L2 error data high capture register (L2_Cache_L2CAPTDATAHI)                          | 32                 | R      | 0000_0000h  | 6.7.11/219       |
| 2_0E24               | L2 error data low capture register (L2_Cache_L2CAPTDATALO)                           | 32                 | R      | 0000_0000h  | 6.7.12/220       |
| 2_0E28               | L2 error syndrome register (L2_Cache_L2CAPTECC)                                      | 32                 | R      | 0000_0000h  | 6.7.13/220       |
| 2_0E40               | L2 error detect register (L2_Cache_L2ERRDET)                                         | 32                 | w1c    | 0000_0000h  | 6.7.14/222       |
| 2_0E44               | L2 error disable register (L2_Cache_L2ERRDIS)                                        | 32                 | R/W    | 0000_0000h  | 6.7.15/224       |
| 2_0E48               | L2 error interrupt enable register (L2_Cache_L2ERRINTEN)                             | 32                 | R/W    | 0000_0000h  | 6.7.16/226       |
| 2_0E4C               | L2 error attributes capture register (L2_Cache_L2ERRATTR)                            | 32                 | R/W    | 0000_0000h  | 6.7.17/228       |
| 2_0E50               | L2 error address capture register low (L2_Cache_L2ERRADDRL)                          | 32                 | R      | 0000_0000h  | 6.7.18/230       |
| 2_0E54               | L2 error address capture register high (L2_Cache_L2ERRADDRH)                         | 32                 | R      | 0000_0000h  | 6.7.19/230       |
| 2_0E58               | L2 error control register (L2_Cache_L2ERRCTL)                                        | 32                 | R/W    | 0000_0000h  | 6.7.20/231       |

# 6.7.1 L2 control register (L2\_Cache\_L2CTL)

The L2 control register (L2CTL), shown in the figure below, controls configuration and operation of the L2/SRAM array. The sequence for modifying L2CTL is as follows:

- 1. mbar
- 2. isync
- 3. **stw** (WIMG = 01xx) CCSRBAR +  $0x2_0000$
- 4. **lwz** (WIMG = 01xx) CCSRBAR +  $0x2_0000$
- 5. mbar

Address: 2\_0000h base + 0h offset = 2\_0000h



#### L2\_Cache memory map/register definition

## L2\_Cache\_L2CTL field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                              |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0              | L2 enable. Used to enable the L2 array (cache or memory-mapped SRAM).                                                                                                                                                                                                                                                    |
| L2E            | Note that L2I can be set regardless of the value of L2E.                                                                                                                                                                                                                                                                 |
|                | The L2 SRAM (cache and memory-mapped SRAM) is disabled and is not accessed for reads, snoops, or writes. Setting the L2 flash invalidate bit (L2I) is allowed.  The L2 SRAM (cache an memory manned SRAM) is applied.                                                                                                    |
| 1              | 1 The L2 SRAM (cache or memory-mapped SRAM) is enabled.                                                                                                                                                                                                                                                                  |
| 1<br>L2I       | L2 flash invalidate.                                                                                                                                                                                                                                                                                                     |
|                | Data to memory-mapped SRAM are unaffected by the flash invalidate. The hardware automatically clears L2I when the invalidate is complete.                                                                                                                                                                                |
|                | <ul> <li>The L2 status and LRU bits are not being cleared.</li> <li>Setting L2I invalidates the L2 cache globally by clearing all the L2 status bits, as well as the LRU algorithm. Memory-mapped SRAM is unaffected.</li> </ul>                                                                                         |
| 2–3<br>L2SIZ   | L2 SRAM size (read only). Indicates the total available size of on-chip memory array (to be configured as cache or memory-mapped SRAM).                                                                                                                                                                                  |
|                | 00 Reserved                                                                                                                                                                                                                                                                                                              |
|                | 01 256 KB                                                                                                                                                                                                                                                                                                                |
|                | 10 Reserved 11 Reserved                                                                                                                                                                                                                                                                                                  |
| 4–8            | This field is reserved.                                                                                                                                                                                                                                                                                                  |
| -              | Reserved                                                                                                                                                                                                                                                                                                                 |
| 9<br>L2DO      | L2 data-only. Reserved in full memory-mapped SRAM mode. L2DO may be changed while the L2 is enabled or disabled.                                                                                                                                                                                                         |
|                | Note that if L2DO and L2IO are both set, no new lines are allocated into the L2 cache for any processor transactions, and processor writes and castouts that hit existing data in the cache invalidate those lines rather than updating them.                                                                            |
|                | 0 The L2 cache allocates entries for instruction fetches that miss in the L2.                                                                                                                                                                                                                                            |
|                | 1 The L2 cache allocates entries for processor data loads that miss in the L2 and for processor L1 castouts but does not allocate entries for instruction fetches that miss in the L2. Instruction accesses that hit in the L2, data accesses, and accesses from the system (including I/O stash writes) are unaffected. |
| 10<br>L2IO     | L2 instruction-only. Reserved in full memory-mapped SRAM mode. Causes the L2 cache to allocate lines for instruction cache transactions only. L2IO may be changed while the L2 is enabled or disabled.                                                                                                                   |
|                | Note that if L2DO and L2IO are both set, no new lines are allocated into the L2 cache for any processor transactions, and processor writes and castouts that hit existing data in the cache invalidate those lines rather than updating them.                                                                            |
|                | 0 The L2 cache entries are allocated for data loads that miss in the L2 and for processor L1 castouts.                                                                                                                                                                                                                   |
|                | 1 The L2 cache allocates entries for instruction fetch misses, but does not allocate entries for processor data transactions. Data accesses that hit in the L2, instruction accesses, and accesses from the system (including I/O stash writes) are unaffected.                                                          |
| 11<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                         |
| 12<br>L2INTDIS | Cache read intervention disable. Reserved for full memory-mapped SRAM mode. Used to disable cache read intervention. May be changed while the L2 is enabled or disabled.                                                                                                                                                 |

## L2\_Cache\_L2CTL field descriptions (continued)

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                  | O Cache intervention is enabled. The ECM ensures that if a data read from another device hits in the L2 cache, it is serviced from the L2 cache.                                                                                                                                                                                                                                                             |  |  |  |
|                  | 1 Cache intervention is disabled                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 13-15<br>L2SRAM  | L2 SRAM configuration. Determines the L2 cache/memory-mapped SRAM allocation of the on-chip memory array. SRAM size depends on the value of L2SIZ. Since L2SIZ is 256 KB, SRAM can have sizes from 32 KB to 256 KB.                                                                                                                                                                                          |  |  |  |
|                  | For one SRAM region L2SRBAR0 is used and for two SRAM regions L2SRBAR0 and L2SRBAR1 are used. Regions of the array that are not allocated to SRAMs are used as cache memory.                                                                                                                                                                                                                                 |  |  |  |
|                  | To change these bits, the L2 must be disabled (L2CTL[L2E] = 0).                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                  | Note that when setting L2SRAM after cache has been enabled, L2I should be set as well. The fields can be set simultaneously, and this step is not needed if SRAM size is getting smaller.                                                                                                                                                                                                                    |  |  |  |
|                  | 000 No SRAM. Entire array is cache.                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                  | 001 Entire array is a single SRAM ( 256 -KB SRAM for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|                  | 010 One half of the array is an SRAM ( 128 -KB SRAM for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                  | 011 Both halves of the array are SRAMs (two 128 -KB SRAMs for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                  | 100 One quarter of the array is an SRAM (one 64 -KB SRAM for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                  | 101 Two quarters of the array are SRAMs (two 64 -KB SRAMs for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                  | One eighth of the array is an SRAM (one 32 -KB SRAM for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                  | 111 Two eighths of the array are SRAMs (two 32 -KB SRAMs for L2SIZ = 256 KB)                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| 16–17            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 18<br>L2LO       | L2 cache lock overflow. Reserved in full memory-mapped SRAM mode. This sticky bit is set if an overlock condition is detected in the L2 cache. A lock overflow is triggered either by executing instruction or data cache block touch and lock set instructions or by performing L2 cache external writes with lock set. If all ways are locked and an attempt to stash is made, the stash is not allocated. |  |  |  |
|                  | The L2 cache did not encounter a lock overflow. L2LO is cleared only by software.                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                  | 1 The L2 cache encountered a lock overflow condition.                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 19<br>L2SLC      | L2 snoop lock clear. This sticky bit is set if a snoop invalidated a locked data cache line. Note that the lock bit for that line is cleared whenever the line is invalidated. L2SLC is reserved in full memory-mapped SRAM mode.                                                                                                                                                                            |  |  |  |
|                  | 0 A snoop did not invalidate a locked L2 cache line. L2SLC is cleared only by software.                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                  | 1 The L2 cache encountered a snoop that invalidated a locked line.                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| 20               | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 21               | L2 cache lock bits flash reset. The L2 cache must be enabled (L2CTL[L2E] = 1) for reset to occur. This                                                                                                                                                                                                                                                                                                       |  |  |  |
| L2LFR            | field is reserved in full memory-mapped SRAM mode.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                  | 0 The L2 cache lock bits are not cleared or the clear operation completed.                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                  | 1 A reset operation is issued that clears each L2 cache line's lock bits. Depending on the L2LFRID                                                                                                                                                                                                                                                                                                           |  |  |  |
|                  | value, data or instruction locks, or both, can be reset. Cache access is blocked during this time. After L2LFR is set, the L2 cache unit automatically clears L2LFR when the reset operation is complete (if L2CTL[L2E] is set).                                                                                                                                                                             |  |  |  |
| 22–23<br>L2LFRID | L2 cache lock bits flash reset select instruction or data. Indicates whether data or instruction lock bits or both are reset.                                                                                                                                                                                                                                                                                |  |  |  |
|                  | 00 Not used                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |

#### L2\_Cache memory map/register definition

## L2\_Cache\_L2CTL field descriptions (continued)

| Field               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                     | 01 Reset data locks if L2LFR = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                     | 10 Reset instruction locks if L2LFR = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                     | 11 Reset both data and instruction locks if L2LFR = 1.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 24–27<br>-          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 28                  | L2 stash allocate disable. Disables allocation of lines for stashing.                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| L2STASHDIS          | This bit does NOT affect the updating of lines that are already resident in the cache and have the stash attribute set or hit a stash range. Such lines are updated even if this bit is set.                                                                                                                                                                                                                                                                             |  |  |
|                     | NOTE: To change this bit, the L2 must be disabled (L2CTL[L2E] = 0).                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                     | The L2 cache allocates lines for global writes that hit in a stash range or that have the stashing attribute set.                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                     | 1 The L2 does not allocate lines for stashed writes.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 29<br>-             | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 30–31<br>L2STASHCTL | L2 stash configuration. This field reserves regions of the cache for stash-only operation. That is, blocks of each cache set are reserved so that they can only be allocated for stash data. If such a region is created, processor reads and writes are not allocated into this region; it can only be populated by stash writes. Similarly, stash writes are only allocated into this region. This prevents processor and stashed I/O data from polluting one another. |  |  |
|                     | Like L2SRAM configuration, stash-only regions subtract from the amount of the on-chip memory that is available to the processor as cache. If the L2SRAM configuration uses the entire on-chip memory array as SRAM, then no stash-only region can be created.                                                                                                                                                                                                            |  |  |
|                     | To change these bits, the L2 must be disabled (L2CTL[L2E] = 0). This field has no effect if the L2STASHDIS bit is set.                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                     | OO No stash-only region. Stashed writes are allocated across the entire cache and can evict processor data and can be evicted by processor data.                                                                                                                                                                                                                                                                                                                         |  |  |
|                     | One half of the array is a stash-only cache (way4, way5, way6 & way7 of each set)                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                     | 10 One quarter of the array is a stash-only cache (way6 & way7 of each set)                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                     | One eighth of the array is a stash-only cache (way7 of each set)                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |

# 6.7.2 L2 cache way allocation for processors (L2\_Cache\_L2CWAP)

The L2 cache way allocation for processors (L2CWAP) register, shown in the figure below, allows the L2 cache to be programmed to distribute eight ways between two processor cores. A pointer is used to set the ways allocated between processor 0 and processor 1.



L2\_Cache\_L2CWAP field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                       |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0<br>ENABLE    | L2 cache way pointer enable. The L2 cache uses the pointer value only when ENABLE is set.                                                                                                                                                                                                         |  |  |
|                | The L2 way pointer is disabled. No ways are allocated only for processor 0 or for processor 1. All ways (except ways allocated for SRAM and stashing) are shared between processors.                                                                                                              |  |  |
|                | 1 The L2 way pointer is enabled. Ways are allocated for processors based on way pointer.                                                                                                                                                                                                          |  |  |
| 1–3<br>POINTER | L2 cache way pointer. This pointer is used to allocate ways between processor 0 and processor 1. To change this field the L2 must be disabled (L2CTL[L2E] = 0).                                                                                                                                   |  |  |
|                | If ways have been allocated for SRAM (L2CTL[13-15]) or stashing (L2CTL[30-31]), way allocation is affected as noted in the following examples. In general, when allocating ways among SRAM, stashing, and processors, the controller gives SRAM first preference, then stashing, then processors. |  |  |
|                | Suppose 2 ways are allocated for SRAM and 2 ways are allocated for stashing and POINTER = 100                                                                                                                                                                                                     |  |  |
|                | Way0 -> SRAM                                                                                                                                                                                                                                                                                      |  |  |
|                | Way1 -> SRAM                                                                                                                                                                                                                                                                                      |  |  |
|                | Way2 -> Processor 0                                                                                                                                                                                                                                                                               |  |  |
|                | Way3 -> Processor 0                                                                                                                                                                                                                                                                               |  |  |
|                | Way4 -> Processor 1                                                                                                                                                                                                                                                                               |  |  |
|                | Way5 -> Processor 1                                                                                                                                                                                                                                                                               |  |  |

### L2\_Cache memory map/register definition

## L2\_Cache\_L2CWAP field descriptions (continued)

| Field | Description                                                                                                                                                                                             |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       | Way6 -> Stash                                                                                                                                                                                           |  |  |
|       | Way7 -> Stash                                                                                                                                                                                           |  |  |
|       | Suppose 4 ways are allocated for SRAM and 2 ways are allocated for stashing and POINTER = 100                                                                                                           |  |  |
|       | Way0 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way1 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way2 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way3 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way4 -> Processor 1                                                                                                                                                                                     |  |  |
|       | Way5 -> Processor 1                                                                                                                                                                                     |  |  |
|       | Way6 -> Stash                                                                                                                                                                                           |  |  |
|       | Way7 -> Stash                                                                                                                                                                                           |  |  |
|       | Suppose 2 ways are allocated for SRAM and no ways are allocated for stashing and POINTER = 100                                                                                                          |  |  |
|       | Way0 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way1 -> SRAM                                                                                                                                                                                            |  |  |
|       | Way2 -> Processor 0/Stash                                                                                                                                                                               |  |  |
|       | Way3 -> Processor 0/Stash                                                                                                                                                                               |  |  |
|       | Way4 -> Processor 1/Stash                                                                                                                                                                               |  |  |
|       | Way5 -> Processor 1/Stash                                                                                                                                                                               |  |  |
|       | Way6 -> Processor 1/Stash                                                                                                                                                                               |  |  |
|       | Way7 -> Processor 1/Stash                                                                                                                                                                               |  |  |
|       | The following description for way pointer values assumes that no ways are allocated for L2SRAM (L2CTL[13-15]) and L2STASH (L2CTL[30-31]).                                                               |  |  |
|       | 000 Way0-way7 are allocated for processor 1 and no ways are allocated for processor 0.                                                                                                                  |  |  |
|       | 001 Way0 is allocated for processor 0 and way1-way7 are allocated for processor 1.                                                                                                                      |  |  |
|       | 010 Way0-way1 are allocated for processor 0 and way2-way7 are allocated for processor 1.                                                                                                                |  |  |
|       | <ul> <li>Way0-way2 are allocated for processor 0 and way3- way7 are allocated for processor 1.</li> <li>Way0-way3 are allocated for processor 0 and way4-way7 are allocated for processor 1.</li> </ul> |  |  |
|       | 101 Way0-way4 are allocated for processor 0 and way5-way7 are allocated for processor 1.                                                                                                                |  |  |
|       | 110 Way0-way5 are allocated for processor 0 and way6-way7 are allocated for processor 1.                                                                                                                |  |  |
|       | 111 Way0-way6 are allocated for processor 0 and way7 is allocated for processor 1.                                                                                                                      |  |  |
| 4–31  | This field is reserved.                                                                                                                                                                                 |  |  |
| -     | Reserved                                                                                                                                                                                                |  |  |

# 6.7.3 L2 cache external write address register n (L2\_Cache\_L2CEWARn)

The L2CEWAR *n* registers contain the lower 24 bits of the 28-bit L2 cache external write base address. Each of these registers has identical fields, as shown in the figure below.





#### L2\_Cache\_L2CEWARn field descriptions

| Field      | Description                                                                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Contains the lower 24 bits of the 28-bit L2 cache external write base address. Note that the upper 4 bits of the base address are in L2CEWAREA $n$ [ADDR]. |
| 24–31<br>- | This field is reserved. Reserved                                                                                                                           |

# 6.7.4 L2 cache external write address register extended address n (L2\_Cache\_L2CEWAREAn)

The L2 cache external write address registers extended address (L2CEWAREA n), shown in the figure below, contain the upper 4 bits of the 28-bit L2 cache external write base address.

Address:  $2_{0000h}$  base + 14h offset + (16d  $\times$  i), where i=0d to 3d



#### L2\_Cache\_L2CEWAREAn field descriptions

| Field         | Description                                                                                                                                  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>-     | This field is reserved. Reserved                                                                                                             |
| 28–31<br>ADDR | Contains the upper 4 bits of the L2 cache external write base address. Note that the rest of the base address is in L2CEWAR <i>n</i> [ADDR]. |

# 6.7.5 L2 cache external write control register n (L2\_Cache\_L2CEWCRn)

The L2CEWAR n /L2CEWAREA n address registers work with the L2 cache external write control registers 0-3 (L2CEWCR n), shown in the figure below, to control cache external write functionality.



### L2\_Cache\_L2CEWCRn field descriptions

| Field           | Description                                                                                                                                                                                                                                                          |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0<br>E          | External write enable. An external write matching the address window defined by L2CEWAR $n$ / L2CEWAREA $n$ /L2CEWCR $n$ is allocated or updated in the L2 cache.                                                                                                    |  |  |
|                 | 0 External writes for the L2CEWAR n /L2CEWAREA n /L2CEWCR n set are disabled.                                                                                                                                                                                        |  |  |
|                 | 1 External writes are enabled for the L2CEWAR <i>n</i> /L2CEWAREA <i>n</i> /L2CEWCR <i>n</i> set.                                                                                                                                                                    |  |  |
| 1<br>LOCK       | Lock lines in the targeted cache. An external write matching the address window defined by L2CEWAR $n$ / L2CEWAREA $n$ /L2CEWCR $n$ is locked in the L2 cache when it is allocated or updated.                                                                       |  |  |
|                 | 0 The locked bit is not set when a line is allocated unless explicitly specified by transaction attributes.                                                                                                                                                          |  |  |
|                 | 1 Cache lines are allocated as locked. A hit to a valid, unlocked line sets the lock.                                                                                                                                                                                |  |  |
| 2–3             | This field is reserved. Reserved                                                                                                                                                                                                                                     |  |  |
| 4–31<br>SIZMASK | Mask size. Defines the size of the naturally aligned address region for cache external writes. The address region must be aligned to a boundary that is a multiple of the mask size. Any value not listed below is illegal and produces boundedly undefined results. |  |  |
|                 | 1111 1111 1111 1111 1111 1111 256 bytes                                                                                                                                                                                                                              |  |  |
|                 | 1111 1111 1111 1111 1111 1110 512 bytes                                                                                                                                                                                                                              |  |  |
|                 | 1111 1111 1111 1111 1111 1100 1 KB                                                                                                                                                                                                                                   |  |  |
|                 | 1111 1111 1111 1111 1111 1000 2 KB                                                                                                                                                                                                                                   |  |  |
|                 | 1111 1111 1111 1111 1111 0000 4 KB                                                                                                                                                                                                                                   |  |  |

#### L2\_Cache\_L2CEWCRn field descriptions (continued)

| Field |      | Description                          |
|-------|------|--------------------------------------|
| 1     | 1111 | 1111 1111 1111 1111 1110 0000 8 KB   |
| 1     | 1111 | 1111 1111 1111 1111 1100 0000 16 KB  |
| 1     | 1111 | 1111 1111 1111 1111 1000 0000 32 KB  |
| 1     | 1111 | 1111 1111 1111 1111 0000 0000 64 KB  |
| 1     | 1111 | 1111 1111 1111 1110 0000 0000 128 KB |
| 1     | 1111 | 1111 1111 1111 1100 0000 0000 256 KB |
| 1     | 1111 | 1111 1111 1111 1000 0000 0000 512 KB |
| 1     | 1111 | 1111 1111 1111 0000 0000 0000 1 MB   |
| 1     | 1111 | 1111 1111 1110 0000 0000 0000 2 MB   |
| 1     | 1111 | 1111 1111 1100 0000 0000 0000 4 MB   |
| 1     | 1111 | 1111 1111 1000 0000 0000 0000 8 MB   |
| 1     | 1111 | 1111 1111 0000 0000 0000 0000 16 MB  |
| 1     | 1111 | 1111 1110 0000 0000 0000 0000 32 MB  |
| 1     | 1111 | 1111 1100 0000 0000 0000 0000 64 MB  |
| 1     | 1111 | 1111 1000 0000 0000 0000 0000 128 MB |
| 1     | 1111 | 1111 0000 0000 0000 0000 0000 256 MB |
| 1     | 1111 | 1110 0000 0000 0000 0000 0000 512 MB |
| 1     | 1111 | 1100 0000 0000 0000 0000 0000 1 GB   |
| 1     | 1111 | 1000 0000 0000 0000 0000 0000 2 GB   |
| 1     | 1111 | 0000 0000 0000 0000 0000 4 GB        |
| 1     | 1110 | 0000 0000 0000 0000 0000 0000 8 GB   |
| 1     | 1100 | 0000 0000 0000 0000 0000 16 GB       |
| 1     | 1000 | 0000 0000 0000 0000 0000 0000 32 GB  |
|       | 0000 | 0000 0000 0000 0000 0000 64 GB       |

# 6.7.6 L2 memory-mapped SRAM base address register n (L2\_Cache\_L2SRBARn)

The L2 memory-mapped SRAM base address registers (L2SRBAR *n* ) contain the lower 18 bits of the 22 -bit SRAM base address.

| SRAM Partition | Bits Required for SRAM Offset | Bits Used for Actual Base Address |
|----------------|-------------------------------|-----------------------------------|
| 64 KB          | 16                            | 20 (0-19)                         |
| 128 KB         | 17                            | 19 (0-18)                         |
| 256 KB         | 18                            | 18 (0-17)                         |

When enabled, the windows defined in L2SRBAR *n* and L2SRBAREA *n* supersede all other mappings of these addresses for processor and global (snoopable) I/O transactions. Therefore, SRAM windows must never overlap configuration space as defined by CCSRBAR (see .) Overlapping SRAM and local access windows is discouraged because processor and snoopable I/O transactions would map to the SRAM while non-snooped I/

#### L2\_Cache memory map/register definition

O transactions would be mapped by the local access windows. Only if all accesses to the SRAM address range are snoopable can results be consistent if SRAM and local access windows overlap.





#### L2\_Cache\_L2SRBARn field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–17<br>ADDR | Contains the lower 18 bits of the 22-bit L2 memory-mapped SRAM base address; the upper 4 bits are contained in L2SRBAREA <i>n</i> [ADDR]. (Note that some of these bits may not be needed, depending on how the L2 cache is partitioned.) The combined base address from L2SRBAREA <i>n</i> [ADDR] II L2SRBAR <i>n</i> [ADDR] is used as shown in L2 memory-mapped SRAM base address register n (L2_Cache_L2SRBAR <i>n</i> ) |
|              | Unused bits of the base address are masked off by the hardware                                                                                                                                                                                                                                                                                                                                                               |
| 18–31<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                             |

# 6.7.7 L2 memory-mapped SRAM base address register extended address n (L2\_Cache\_L2SRBAREAn)

The L2 memory-mapped SRAM base address registers extended address (L2SRBAREA n), shown in the figure below, contain the upper 4 bits of the L2 cache SRAM base address.

Address:  $2_{0000h}$  base + 104h offset + (8d × i), where i=0d to 1d



### L2\_Cache\_L2SRBAREAn field descriptions

| Field     | Description                                                                                                                                           |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>- | This field is reserved. Reserved                                                                                                                      |
|           | Contains the upper 4 bits of the L2 cache SRAM base address. Note that the 18 low-order bits of the base address are contained in L2SRBAR $n$ [ADDR]. |

## 6.7.8 L2 error injection mask high register (L2\_Cache\_L2ERRINJHI)

The L2 cache includes support for injecting errors into the L2 data, data ECC, or tag. This may be used to test error recovery software by deterministically creating error scenarios.

The preferred method for error injection is to set all data pages to cache-inhibited (MMU TLB entry I = 1) except a scratch page, set L2CTL[L2DO] to prevent allocation of instruction accesses, and invalidate the L2 by setting L2CTL[L2I] = 1. The following code sequence triggers an error, then detects it (A is an address in the scratch page):

Data or tag errors are injected into the line, according to the error injection settings in L2ERRINJHI, L2ERRINJLO, and L2ERRINJCTL, at allocation. The final load detects and reports the error (if enabled) and allows software to examine the offending data, address, and attributes.

Note that error injection enable bits in L2ERRINJCTL must be cleared by software and the L2 must be invalidated (by setting L2CTL[L2I]) before resuming L2 normal operation. The figure below shows the L2 error injection mask high register (L2ERRINJHI).

Address: 2\_0000h base + E00h offset = 2\_0E00h



#### L2\_Cache\_L2ERRINJHI field descriptions

| Field | Description                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Error injection mask/high word. A set bit corresponding to a data path bit causes that bit on the data path to be inverted on cache/SRAM writes if L2ERRINJCTL[DERRIEN] = 1. |

## 6.7.9 L2 error injection mask low register (L2\_Cache\_L2ERRINJLO)

The figure below shows the L2 error injection mask low register (L2ERRINJLO).

Address: 2\_0000h base + E04h offset = 2\_0E04h



#### L2\_Cache\_L2ERRINJLO field descriptions

| Field    | Description                                                                                                   |
|----------|---------------------------------------------------------------------------------------------------------------|
|          | Error injection mask/low word. A set bit corresponding to a data path bit causes that bit on the data path to |
| EIMASKLO | be inverted on SRAM writes if L2ERRINJCTL[DERRIEN] = 1.                                                       |

## 6.7.10 L2 error injection tag/ECC control register (L2\_Cache\_L2ERRINJCTL)

The figure below shows the L2 error injection mask control register (L2ERRINJCTL).

Address: 2\_0000h base + E08h offset = 2\_0E08h



#### L2\_Cache\_L2ERRINJCTL field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–14<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15<br>TERRIEN     | <ul> <li>L2 tag array error injection enable</li> <li>No tag errors are injected.</li> <li>All subsequent entries written to the L2 tag array have the parity bit inverted.</li> </ul>                                                                                                                                                                                                                                                                                 |
| 16–21<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 22<br>ECCMB       | <ul> <li>ECC mirror byte enable.</li> <li>ECC byte mirroring is disabled</li> <li>The most significant data path byte is mirrored onto the ECC byte if DERRIEN = 1.</li> </ul>                                                                                                                                                                                                                                                                                         |
| 23<br>DERRIEN     | <ul> <li>L2 data array error injection enable:</li> <li>NOTE: If both ECC mirror byte and data error injection are enabled, ECC mask error injection is performed on the mirrored ECC.</li> <li>No data errors are injected.</li> <li>Subsequent entries written to the L2 data array have data or ECC bits inverted as specified in the data and ECC error injection masks and/or data path byte mirrored onto ECC as specified by ECC mirror byte enable.</li> </ul> |
| 24–31<br>ECCERRIM | Error injection mask for the ECC bits. A set bit corresponding to an ECC bit causes that bit to be inverted on SRAM writes if DERRIEN = 1.                                                                                                                                                                                                                                                                                                                             |

## 6.7.11 L2 error data high capture register (L2\_Cache\_L2CAPTDATAHI)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error capture data high register (L2CAPTDATAHI).

Address: 2\_0000h base + E20h offset = 2\_0E20h



#### L2\_Cache\_L2CAPTDATAHI field descriptions

| Field          | Description       |
|----------------|-------------------|
| 0–31<br>L2DATA | L2 data high word |

## 6.7.12 L2 error data low capture register (L2\_Cache\_L2CAPTDATALO)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error capture data low register (L2CAPTDATALO).





#### L2\_Cache\_L2CAPTDATALO field descriptions

| Field          | Description      |
|----------------|------------------|
| 0–31<br>L2DATA | L2 data low word |

### 6.7.13 L2 error syndrome register (L2\_Cache\_L2CAPTECC)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error syndrome register (L2CAPTECC).

Address: 2\_0000h base + E28h offset = 2\_0E28h



#### L2\_Cache\_L2CAPTECC field descriptions

| Field          | Description                                            |
|----------------|--------------------------------------------------------|
| 0-7<br>ECCSYND | The calculated ECC syndrome of the failing double word |

## L2\_Cache\_L2CAPTECC field descriptions (continued)

| Field              | Description                                  |
|--------------------|----------------------------------------------|
| 8–23<br>-          | This field is reserved. Reserved             |
| 24–31<br>ECCCHKSUM | The data path ECC of the failing double word |

### 6.7.14 L2 error detect register (L2\_Cache\_L2ERRDET)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error detect register (L2ERRDET).







#### L2\_Cache\_L2ERRDET field descriptions

| Field          | Description                                                                                                                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MULL2ERR  | Multiple L2 errors (write 1 to clear)                                                                                                                                                                                           |
|                | 0 Multiple L2 errors of the same type were not detected                                                                                                                                                                         |
|                | 1 Multiple L2 errors of the same type were detected                                                                                                                                                                             |
| 1–26<br>-      | This field is reserved. Reserved                                                                                                                                                                                                |
| 27             | Tag parity error (write 1 to clear)                                                                                                                                                                                             |
| TPARERR        | Note that if an L2 cache tag parity error occurs on an attempt to write a new line, the L2 cache must be Flash invalidated. L2 functionality is not guaranteed if Flash invalidation is not performed after a tag parity error. |
|                | 0 Tag parity error was not detected                                                                                                                                                                                             |
|                | 1 Tag parity error was detected                                                                                                                                                                                                 |
| 28<br>MBECCERR | Multiple-bit ECC error (write 1 to clear)                                                                                                                                                                                       |
|                | 0 Multiple-bit ECC errors were not detected                                                                                                                                                                                     |
|                | 1 Multiple-bit ECC errors were detected                                                                                                                                                                                         |
| 29<br>SBECCERR | Single-bit ECC error (write 1 to clear)                                                                                                                                                                                         |
|                | 0 Single-bit ECC error was not detected                                                                                                                                                                                         |
|                | 1 Single-bit ECC error was detected.                                                                                                                                                                                            |
| 30<br>-        | This field is reserved. Reserved                                                                                                                                                                                                |
| 31<br>L2CFGERR | L2 configuration error (write 1 to clear)                                                                                                                                                                                       |
|                | 0 L2 configuration errors were not detected                                                                                                                                                                                     |
|                | L2 illegal configuration error detected. Reports inconsistencies between the L2SRAM, L2STASHDIS and L2STASHCTL fields of the L2 control register (L2CTL)                                                                        |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 6.7.15 L2 error disable register (L2\_Cache\_L2ERRDIS)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error disable register (L2ERRDIS).



L2\_Cache\_L2ERRDIS field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–26<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 27<br>TPARDIS  | Tag parity error disable  0 Tag parity error detection enabled 1 Tag parity error detection disabled                                                                                                                                                                                                                                                                                                                           |
| 28<br>MBECCDIS | Multiple-bit ECC error disable. Note that non-correctable read errors may cause the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If RFXE is zero and this error occurs, MBECCDIS must be cleared and L2ERRINTEN[MBECCINTEN] must be set to ensure that an interrupt is generated.  NOTE: In normal operation, ECC must be enabled. |

## L2\_Cache\_L2ERRDIS field descriptions (continued)

| Field          | Description                                     |
|----------------|-------------------------------------------------|
|                | 0 Multiple-bit ECC error detection enabled      |
|                | 1 Multiple-bit ECC error detection disabled     |
| 29<br>SBECCDIS | Single-bit ECC error disable                    |
| OBLOODIO       | NOTE: In normal operation, ECC must be enabled. |
|                | 0 Single-bit ECC error detection enabled        |
|                | 1 Single-bit ECC error detection disabled       |
| 30             | This field is reserved.                         |
| -              | Reserved                                        |
| 31<br>L2CFGDIS | L2 configuration error disable                  |
|                | 0 L2 configuration error detection enabled      |
|                | 1 L2 configuration error detection disabled     |

## 6.7.16 L2 error interrupt enable register (L2\_Cache\_L2ERRINTEN)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error interrupt enable register (L2ERRINTEN). When an enabled error condition exists, the L2 signals an interrupt to the core through the internal int signal.





#### L2\_Cache\_L2ERRINTEN field descriptions

| Field            | Description                                                                                                                                                                                                      |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–26             | This field is reserved.                                                                                                                                                                                          |
| -                | Reserved                                                                                                                                                                                                         |
| 27<br>TPARINTEN  | Tag parity error reporting enable                                                                                                                                                                                |
|                  | 0 Tag parity error reporting disabled                                                                                                                                                                            |
|                  | 1 Tag parity error reporting enabled                                                                                                                                                                             |
| 28<br>MBECCINTEN | Multiple-bit ECC error reporting enable. Note that non-correctable read errors may cause the assertion of core_fault_in , which causes the core to generate a machine check interrupt, unless it is disabled (by |

## L2\_Cache\_L2ERRINTEN field descriptions (continued)

| Field            | Description                                                                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | clearing HID1[RFXE]). If RFXE is zero and this error occurs, L2ERRDIS[MBECCDIS] must be cleared and MBECCINTEN must be set to ensure that an interrupt is generated. |
|                  | Multiple-bit ECC error reporting disabled     Multiple-bit ECC error reporting enabled                                                                               |
| 29<br>SBECCINTEN | Single-bit ECC error reporting enable                                                                                                                                |
|                  | <ul><li>0 Single-bit ECC error reporting disabled</li><li>1 Single-bit ECC error reporting enabled</li></ul>                                                         |
| 30<br>-          | This field is reserved. Reserved                                                                                                                                     |
| 31<br>L2CFGINTEN | L2 configuration error reporting enable                                                                                                                              |
|                  | <ul> <li>L2 configuration error reporting disabled</li> <li>L2 configuration error reporting enabled</li> </ul>                                                      |

## L2 error attributes capture register (L2\_Cache\_L2ERRATTR)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error attributes capture register (L2ERRATTR).



Address: 2\_0000h base + E4Ch offset = 2\_0E4Ch





L2\_Cache\_L2ERRATTR field descriptions

| Field           | Description                                                     |
|-----------------|-----------------------------------------------------------------|
| 0–1<br>-        | This field is reserved. Reserved                                |
| 2–3<br>DWNUM    | Double-word number of the detected error (data ECC errors only) |
| 4 -             | This field is reserved. Reserved                                |
| 5–7<br>TRANSSIZ | Transaction size for detected error Single-beat Burst           |

## L2\_Cache\_L2ERRATTR field descriptions (continued)

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 000 8 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 001 1 byte 16 bytes                                                                                                                                                                                                                                                                                                                                                                            |
|                    | 010 2 bytes 32 bytes                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 011 3 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 100 4 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 101 5 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 110 6 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
|                    | 111 7 bytes Reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 8<br>BURST         | Burst transaction for detected error                                                                                                                                                                                                                                                                                                                                                           |
|                    | 0 Single-beat (≤ 64 bits) transaction                                                                                                                                                                                                                                                                                                                                                          |
|                    | 1 Burst transaction                                                                                                                                                                                                                                                                                                                                                                            |
| 9–10               | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                        |
| -                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 11–15<br>TRANSSRC  | Transaction source for detected error                                                                                                                                                                                                                                                                                                                                                          |
|                    | 00000 External (system logic)                                                                                                                                                                                                                                                                                                                                                                  |
|                    | 10000 Processor (instruction)                                                                                                                                                                                                                                                                                                                                                                  |
|                    | 10001 Processor (data)                                                                                                                                                                                                                                                                                                                                                                         |
| 16–17<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                               |
| 18–19<br>TRANSTYPE | Transaction type for detected error                                                                                                                                                                                                                                                                                                                                                            |
|                    | 00 Snoop (tag/status read)                                                                                                                                                                                                                                                                                                                                                                     |
|                    | 01 Write                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | 10 Read                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | 11 Read-modify-write                                                                                                                                                                                                                                                                                                                                                                           |
| 20–30<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                               |
| 31<br>VALINFO      | L2 capture registers valid                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul> <li>L2 capture registers contain no valid information or no enabled errors were detected.</li> <li>L2 capture registers contain information of the first detected error which has reporting enabled.</li> <li>Software must clear this bit to unfreeze error capture so error detection hardware can overwrite the capture address/data/attributes for a newly detected error.</li> </ul> |

## 6.7.18 L2 error address capture register low (L2\_Cache\_L2ERRADDRL)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error address capture register low (L2ERRADDRL).





#### L2\_Cache\_L2ERRADDRL field descriptions

| Field           | Description                                          |
|-----------------|------------------------------------------------------|
| 0–31<br>L2ADDRL | L2 address bits 4-35 corresponding to detected error |

## 6.7.19 L2 error address capture register high (L2\_Cache\_L2ERRADDRH)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error address capture register high (L2ERRADDRH).

Address: 2\_0000h base + E54h offset = 2\_0E54h



#### L2\_Cache\_L2ERRADDRH field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–27  | This field is reserved. |
| -     | Reserved                |

#### L2\_Cache\_L2ERRADDRH field descriptions (continued)

| Field            | Description                                         |
|------------------|-----------------------------------------------------|
| 28–31<br>L2ADDRH | L2 address bits 0-3 corresponding to detected error |

## 6.7.20 L2 error control register (L2\_Cache\_L2ERRCTL)

The error control and capture registers control detection and reporting of tag parity, ECC and L2 configuration errors. L2 configuration errors are illegal combinations of L2 size and block size and are detected when the L2 is enabled (L2CTL[L2E] = 1). The figure below shows the L2 error control register (L2ERRCTL).





#### L2\_Cache\_L2ERRCTL field descriptions

| Field             | Description                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7               | This field is reserved. Reserved                                                                                                                                               |
| 8–15<br>L2CTHRESH | L2 cache threshold  Threshold value for the number of ECC single-bit errors that are detected before reporting an error condition.                                             |
| 16–23<br>-        | This field is reserved. Reserved                                                                                                                                               |
| 24–31<br>L2CCOUNT | L2 count  Counts ECC single-bit errors detected. If L2CCOUNT equals the ECC single-bit error trigger threshold, an error is reported if single-bit error reporting is enabled. |

## 6.8 External writes to the L2 cache (cache stashing)

Data from an I/O master can be allocated into the L2 cache while simultaneously being written to memory.

External (stashed) writes can be performed from any I/O master, such as the following:

• Ethernet

#### L2 cache timing

- PCI/PCI-Express
- DMA

Stashing is controlled either by an attribute from the initiator of a write or by address range registers in the L2 cache. New cache lines are allocated for full-cache-line writes (unless the line is already resident in the cache). Sub-cache-line write data is stashed only if the line is already valid in the cache. For these sub-cache-line writes, a read-modify-write process is used to merge the write data with the valid data already in the cache.

For information on how to initiate cache stashing from an I/O master, see the respective chapters for the I/O masters that support stashing.

For address range based control of stashing, the L2 cache external write address registers 0-3 (L2CEWAR*n*) and the L2 cache external write address registers extended address 0-3 (L2CEWAREA*n*) are used with the L2 cache external write control registers 0-3 (L2CEWCR*n*) to control the cache stashing functionality. Each register set (for example L2CEWARO, L2CEWAREAO, and L2CEWCRO) specifies a programmed memory range that can be allocated and optionally locked with a global write transaction. The address register must be naturally aligned to the window size in the corresponding control register. For more information, see L2 cache external write registers.

Note that stashing can occur regardless of whether the L1 cache is enabled or whether the cache-inhibited bit in the MMU is set for the page.

#### 6.8.1 Stash-only cache regions

In order to prevent stashed I/O data from polluting processor data in the L2 cache (and vice versa), it is possible to create stash-only regions. This is controlled by the L2STASHCTL field of L2CTL.

See L2 control register (L2\_Cache\_L2CTL).

If a stash-only region is created, then that region of the cache is only used for stashed I/O data, and stashed I/O data does not cause the eviction of processor data; they are kept in separate ways of each set. The processor may allocate data into the ways of the cache that are not allocated to SRAM or stash-only memory. Replacement within the stash-only region and the processor region is governed by a pseudo-LRU algorithm modified by masks that allow only applicable ways of a cache set to be considered for replacement.

## 6.9 L2 cache timing

Table 6-42 shows the timing of back-to-back loads that miss in the L1 data cache and hit in the L2 cache, assuming the core is running at 2 1/2 times the L2 cache frequency.

The L2 returns the 128 bits containing the requested data (critical quad word) first. This data is forwarded to the result register before the full cache line reloads the L1.

Table 6-42. Fastest read timing-hit in L2

| Core<br>clocks      | 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 |
|---------------------|------------|--------------|--------|-------|---|---|---|---|---|----|----|----|----|----|----|--------|------------|-------------------|--------------------|------------|----|----|----|----|----|----|
| e500 core<br>load 1 | to D-cache | D-cache miss | to CIU | CIU Q |   |   |   |   |   |    |    |    |    |    |    | to CIU | nsn<br>Ten | LSU reads command | LSU reads out data | Result bus |    |    |    |    |    |    |

Table 6-42. Fastest read timing-hit in L2 (continued)

| Core clocks            | 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 |
|------------------------|----|------------|--------------|--------|------|-----------------|---|----|----------|----|------------------|----|-------------------|----|----|-----|----|-------------------|----|----|--------|------------|-------------------|--------------------|------------|----|
| e500 core<br>load 2    |    | to D-cache | D-cache miss | to CIU | CIUQ |                 |   |    |          |    |                  |    |                   |    |    |     |    |                   |    |    | to CIU | rsn<br>Tsn | LSU reads command | LSU reads out data | Result bus |    |
| CCB<br>clocks          | <1 |            | 2            | •      |      | 3               |   | 4  |          |    | 5                |    | 6                 |    |    | 7   |    | 8                 |    |    | 9      |            | 10                |                    | 11         | <  |
| CCB addr<br>bus load 1 |    |            | BG           | 1      | ٦    | ΓS <sup>2</sup> |   |    |          | AA | ACK <sup>3</sup> |    | HIT<br>DAT<br>OMI | Α- |    |     |    |                   |    |    |        |            |                   |                    |            |    |
| CCB addr<br>bus load 2 |    |            |              |        |      |                 |   | BG | <b>i</b> | •  | TS               |    |                   |    | A  | ACK |    | HIT<br>DAT<br>OMI | Α- |    |        |            |                   |                    |            |    |
| CCB data<br>bus load 1 |    |            |              |        |      |                 |   |    |          |    |                  |    |                   |    | D  | ATA |    | DAT               | Ά  |    |        |            |                   |                    |            |    |
| CCB data<br>bus load 2 |    |            |              |        |      |                 |   |    |          |    |                  |    |                   |    |    |     |    |                   |    | D  | АТА    |            | DAT               | Α                  |            |    |

- 1. BG-Bus grant
- 2. TS-Transfer start
- 3. AACK-Address acknowledge

### 6.10 L2 cache and SRAM coherency

This section explains the rules of cache and memory-mapped SRAM coherency.

The term 'snoop transaction' refers to transactions initiated by the system logic or by I/O traffic, as opposed to e500 core-initiated transactions.

#### 6.10.1 L2 cache coherency rules

L2 cache coherency rules are as follows:

- The L2 is non-inclusive of the L1-valid L1 lines may be valid or invalid in the L2.
- The L2 cache holds no modified data. Data is in one of four states-invalid, exclusive, exclusive locked, and stale.
- The L2 allocates entries for data cast out or pushed (non-global, non-write-through write with kill) from the L1 caches.

- Lines for e500 core-initiated burst read transactions are allocated as exclusive in the L2.
- The L2 supports I/O devices reading data from valid lines in the L2 cache (data intervention) if L2CTL[L2INTDIS] = 0. An optional unlock attribute causes I/O reads to clear a lock when the read is performed.
- The L2 cache does not respond to cache-inhibited read transactions.
- e500 core-initiated, cache-inhibited store transactions invalidate the line when they hit on a valid L2 line. If the line is locked, it goes to the stale state. For other write transactions the cache-inhibited bit is ignored.
- Non-burst cacheable write transactions from the e500 core (generated by write-through cacheable stores) update a valid L2 cache line through a read-modify-write operation.
- e500 core cast out transactions that hit on a stale line in the L2 cache cause a data update of the line and a change to the valid locked state for that line.
- An e500 core-initiated, cacheable, non-write-through store that misses in the L1 and hits on a line in the L2 invalidates that line in the L2. If the line is marked exclusive locked, the L2 marks the line as stale.
- Transactions that hit a stale L2 cache line that would cause an allocate if they miss cause a data update of the line (when data arrives from memory) and a change to the line's valid locked state. Data is not supplied by the L2 cache for the read in this case.
- The following transactions kill the data and the respective locks when they hit a valid L2 line:
  - dcbf
  - dcbi
- The L2 cache supports mixed cache external writes and core-initiated writes to the same addresses if the core-initiated writes are marked coherency-required, caching allowed, not write-through (WIMG = 001x) and the external writes are marked coherency-required, caching-allowed.
- The L2 cache supports writes to the L2 cache from peripheral devices or from I/O controllers through snoop write transactions with addresses that hit in a programmed memory range. Full cache line (32-byte) write transactions update the data for a valid line in the L2 and if the line is not valid in the L2, a line is allocated. Sub-cache line write transactions update the data only for valid L2 cache lines through read-modify-write operations.
- The L2 cache supports burst writes that lock an L2 cache line from peripheral devices or from I/O controllers through write transactions with addresses that hit in a programmed memory range that has the lock attribute set.
- The L2 cache supports burst writes that allocate and/or lock an L2 cache line from peripheral devices or I/O controllers through a write allocate transaction. See the system logic programming model (for example, that of the DMA controller) for details on how to set the transaction type for cache external writes to the L2.

### 6.10.2 Memory-mapped SRAM coherency rules

Memory-mapped SRAM coherency rules are as follows:

- External (non-core-initiated) accesses to memory-mapped SRAM must be marked coherency-required. External accesses to memory-mapped SRAM marked coherency-not-required may cause an address unavailable error.
- Accesses to memory-mapped SRAM are cacheable only in the corresponding e500 L1 caches. External accesses must be marked cache-inhibited or be performed with non-caching transactions.

## 6.11 L2 cache locking

The caches can be locked and cleared using the following methods:

- Cache locking methods
  - Individual line locks are set and cleared using instructions defined by the e500 cache locking APU, which is part of the Freescale Embedded Implementation Standards (EIS). These instructions include Data Cache Block Touch and Lock Set (dcbtsls), Data Cache Block Touch for Store and Lock Set (dcbtstls), and Instruction Cache Block Touch and Lock Set (icbtls). For detailed information about these instructions, see the *PowerPC e500 Core Reference Manual*.
  - A lock attribute can be attached to write operations.
  - Individual line locks are set and cleared through core-initiated instructions, by external reads or writes, or by accesses to programmed memory ranges defined in L2 cache external write address registers (L2CEWAR*n*).
  - The entire cache can be locked by setting configuration registers appropriately
- Methods for clearing locks
  - Individual locks can be cleared by cache locking APU instructions (Instruction Cache Block Lock Clear (**icblc**) and Data Cache Block Lock Clear (**dcblc**)) or by snooped flush unless the entire cache is locked.
  - Flash clearing of all instruction and/or data locks can be done by writes to configuration registers.
  - An unlock attribute can be attached to I/O read operations.

## 6.11.1 Locking the entire L2 cache

The entire L2 cache can be locked by setting L2CTL[L2DO] = 1 and L2CTL[L2IO] = 1. This has the effect of preventing any further allocation of new lines in the cache by core requests.

If there are lines in the cache that are not valid, they cannot be used by core requests until the cache is unlocked. While the cache is locked, read requests are serviced as normal, and snooping continues as normal to maintain coherency. Lines invalidated to satisfy coherency requirements cannot be reallocated by core requests while the cache remains locked. The L2 cache can be unlocked by clearing L2CTL[L2IO] and/or L2CTL[L2DO]. Note that L2CTL[L2DO] and L2CTL[L2IO] have no effect on cache external write allocations or memory-mapped SRAM.

Note that this form of cache locking does not use the lock bits of the cache and cannot be cleared by resetting the cache or lock bits.

## 6.11.2 Locking programmed memory ranges

A programmed memory range can be locked with a snoop write transaction that matches a cache external write address range (specified by L2CEWAR*n*/L2CEWAREA*n* and L2CEWCR*n*).

There are no clearing of locks through the programmed address ranges. Locks can be cleared using clear lock instructions, flushes, read-and-clear-lock snoop (RWNITC with clear lock attribute), or flash clear locks.

## 6.11.3 Locking selected lines

Individual lines are locked when the L2 receives one of the following burst transactions:

- icbtls (CT = 1)-Instruction Cache Block Touch and Lock Set instruction
- **dcbtls** (CT = 1)-Data Cache Block Touch and Lock Set instruction
- **dcbtstls** (CT = 1)-Data Cache Block Touch for Store and Lock Set instruction
- Snoop burst write-If the address hits on a programmed cache external write space with the lock attribute set, or if the write allocate transaction type is used
- Snoop non-burst write-If the address hits on a programmed cache external write space with the lock attribute set

#### L2 cache locking

Note that the core complex broadcasts these instructions to the L2 if the CT field in the instruction specifies the L2 cache (CT = 1). When the L2 cache is specified, data is not placed in the L1, only the L2. If the L1 cache is specified (CT = 0), the L2 does not lock the line, and the data is placed in the L1 (and locked).

When the touch lock set L2 instruction (**dcbtls** or **dcbtstls**) hits are modified in the L1 cache, the modified data is allocated into the L2 cache (and written back to main memory) and a data lock is set. The L1 line state transitions to invalid.

Note that if the L2 receives a request to allocate and lock a line, but all lines in the selected way are locked, the requested L2 line is not allocated and the L2 cache lock overflow bit (L2CTL[L2LO]) is set.

Lines invalidated to satisfy coherency requirements cannot be reallocated while the cache remains locked.

### 6.11.4 Clearing locks on selected lines

Individual locks in the L2 are cleared by a lock clear (**icblc** or **dcblc**, CT = 1) instruction.

This directs the L2 cache to clear a lock on that line if it hits in the L2 cache. Both data and instruction locks are cleared by the **icblc** and **dcblc** instructions.

Note that the lock on a line is cleared if the line is invalidated by a snooped flush transaction, and the line in the cache is available for allocation of a new line of instruction or data unless the entire cache is locked.

#### 6.11.5 Flash clearing of instruction and data locks

Locks for instructions and data are recorded separately in the L2 cache, and they can be flash cleared separately by writing the appropriate value to the L2 cache control register (L2CTL[L2LFR] and L2CTL[L2LFRID]).

Flash invalidating of the L2 (setting L2CTL[L2I]) clears all locks on both instructions and data.

Note that flash clearing is the only way to clear data locks without clearing instruction locks, or to clear instruction locks without clearing data locks. All instructions and snoop transactions that clear locks clear both data and instruction locks.

#### 6.11.6 Locks with stale data

If data is locked in the L2 and either the e500 core performs a cacheable copyback store or a **dcbtst** misses in the L1, the L2 invalidates the line; however, the L2 clears the valid bit for the data, the lock remains, and the line cannot be victimized.

If the e500 core casts out modified data or pushes it in response to a non-flush snoop, the L2 updates the data and sets the valid bit again, maintaining the lock and keeping the data in the cache hierarchy.

## 6.12 PLRU L2 replacement policy

Line replacement is determined using a pseudo least-recently-used (PLRU) algorithm.

There is a valid bit (V0-V7) for each line. To determine the replacement victim (the line to be cast out), there are seven PLRU bits (P0-P6) for each set. PLRU bits are updated every time a new line is allocated and every time an existing line is read by the processor, updated by a write, or invalidated.

Figure 6-43 shows the binary decision tree used to generate the victim line. The eight ways of the L2 cache are labeled W0-W7; the seven PLRU bits are labeled P0-P6.



Figure 6-43. L2 cache line replacement algorithm

#### 6.12.1 PLRU bit update considerations

PLRU bit updates depend on which cache way was last accessed, as summarized in Table 6-43.

| Last Way Accessed |    |    |    | PLRU Bits |    |    |    |
|-------------------|----|----|----|-----------|----|----|----|
|                   | P0 | P1 | P2 | P3        | P4 | P5 | P6 |
| 0                 | 1  | 1  | -  | 1         | -  | -  | -  |
| 1                 | 1  | 1  | -  | 0         | -  | -  | -  |
| 2                 | 1  | 0  | -  | -         | 1  | -  | -  |
| 3                 | 1  | 0  | -  | -         | 0  | -  | -  |
| 4                 | 0  | -  | 1  | -         | -  | 1  | -  |
| 5                 | 0  | -  | 1  | -         | -  | 0  | -  |
| 6                 | 0  | -  | 0  | -         | -  | -  | 1  |
| 7                 | 0  | -  | 0  | -         | -  | -  | 0  |

Table 6-43. PLRU bit update algorithm

When an L2 line is invalidated, the PLRU bits are updated, marking the corresponding way as least-recently used. This causes the invalidated way to be selected as the next victim.

#### 6.12.2 Allocation of lines

The general PLRU algorithm described above must be modified to take into account special features of the L2 cache; namely SRAM regions, line locking, and stash-only regions.

Each of these features reserves ways within each cache set such that some ways are not eligible for allocation/victimization by the general LRU algorithm.

To preserve the state of the ways that are set aside for other special functions, the PLRU pointers are modified by a mask that is a function of the L2 configuration registers, the lock bits in the cache status array, and initiator of the transaction. The mask effectively points the PLRU algorithm away from ways that are not to be considered for replacement.

L2 cache lines are locked through the status array lock bits. There are two lock bits for each way of each set (1024 sets by eight ways). These bits are set or cleared through special L2 controller commands. There are two sets of lock bits, one for instructions (I0-I7) and one for data (D0-D7) for every line. The lock bits act as a mask over the PLRU bits to determine victim selection. The PLRU bits are updated regardless of line locking.

Lock bits are used at allocate time to steer the PLRU algorithm away from selecting locked victims. In the following discussion, the eight lock bits for a particular set are called L0-L7.

```
Where Lock Way i: Li = Di | Ii, i=0...7 (Di = data lock, Ii = instruction lock)
```

An effective value of each PLRU bit is calculated as follows:

These effective PLRU bits are used to select a victim, as indicated in Table 6-44.

| Way selected | Effective PLRU state (binary) | Reduced logic equation      |
|--------------|-------------------------------|-----------------------------|
|              |                               | (using effective PLRU bits) |
| W0           | 00x0xxx                       | ~P0 & ~P1 & ~P3             |
| W1           | 00x1xxx                       | ~P0 & ~P1 & P3              |
| W2           | 01xx0xx                       | ~P0 & P1 & ~P4              |
| W3           | 01xx1xx                       | ~P0 & P1 & P4               |
| W4           | 1x0xx0x                       | P0 & ~P2 & ~P5              |
| W5           | 1x0xx1x                       | P0 & ~P2 & P5               |
| W6           | 1x1xxx0                       | P0 & P2 & ~P6               |
| W7           | 1x1xxx1                       | P0 & P2 & P6                |

Table 6-44. PLRU-based victim selection mechanism

### 6.13 L2 cache operation

This section describes the behavior of the L1 and L2 cache in response to various operations and configurations.

#### 6.13.1 Initialization

This section describes L2 cache initialization and memory-mapped SRAM initialization.

#### 6.13.1.1 L2 cache initialization

After power-on reset the valid bits in the L2 cache status array are in random states. Therefore, it is necessary to perform a flash invalidate before using the array as an L2 cache.

This is done by writing a one to the L2I field of the L2 control register (L2CTL). This can be done before or simultaneously with the write that enables the L2 cache. That is, the L2E and L2I bits of L2CTL can be set simultaneously. The L2I bit clears automatically, so no further writes are necessary.

#### 6.13.1.2 Memory-mapped SRAM initialization

After power-on reset the contents of the data and ECC arrays are random, so all SRAM data must be initialized before it is read.

If the cache is initialized by the processor or any other device that uses sub-cache-line transactions, ECC error checking should be disabled during the initialization process to avoid false ECC errors generated during the read-modify-write process used for sub-cache-line writes to the SRAM array. This is done by setting the multi- and single-bit ECC error disable bits of the L2 error disable register (L2ERRDIS[MBECCDIS, SBECCDIS]). See L2 error disable register (L2\_Cache\_L2ERRDIS). If the array is initialized by a DMA engine using cache-line writes, ECC checking can remain enabled during the initialization process.

#### 6.13.2 Flash invalidation of the L2 cache

The L2 cache may be completely invalidated by setting the L2I bit of the L2 control register (L2CTL).

Note that no data is lost in this process because the L2 cache is a write-through cache and contains no modified data. Flash invalidation of the cache is necessary when the cache is initially enabled and may be necessary to recover from some error conditions such as a tag parity error.

The invalidation process requires several cycles to complete. The L2I bit remains set during this procedure and is then cleared automatically when the procedure is complete. The L2 cache controller issues retries for all transactions on the e500 core complex bus while the flash invalidation process is in progress.

Note that the contents of memory-mapped SRAM regions of the data array are unaffected by a flash invalidation of the L2 cache regions of the array.

#### 6.13.3 Managing errors

This section describes ECC and tag parity errors.

#### 6.13.3.1 ECC errors

An individual soft error that causes a single- or multi-bit ECC error can be cleared from the L2 array simply by performing a **dcbf** instruction on the address captured in the L2ERRADDR register. This invalidates the line in the L2 cache.

When the load that caused the ECC error is performed again, the data is reallocated into the L2 with ECC bits set properly again.

If the threshold for single bit errors set in the L2ERRCTL register is exceeded, then the L2 cache should be flash invalidated to clear out all single-bit errors.

Note that no data is lost by **dcbf**s or flash invalidates, since the L2 cache is write-through and contains no modified data.

#### 6.13.3.2 Tag parity errors

A tag parity error must be fixed by flash invalidating the L2 cache.

Note that a **dcbf** operation to the address that caused the error to be reported is not sufficient since a tag parity error is seen as an L2 miss and does not cause invalidation of the bad tag. Proper L2 operation cannot be guaranteed if an L2 tag parity error is not repaired by a flash invalidation of the entire cache.

#### 6.13.4 L2 cache states

The L2 status array uses four bits for each line to determine the status of the line.

Different combinations of these bits result in different L2 states. The status bits are as follows:

- Valid (V)
- Instruction locked (IL)
- Data locked (DL)
- Stale (T)

#### L2 cache operation

Table 6-45 shows L2 cache states. Note that these conventions are also used in Table 6-46.

IL DL L2 states Т 0 Invalid (I) Х Х Х 1 0 0 0 Exclusive (E) 1 0 0 1 Exclusive data locked (EDL) 1 0 1 0 Exclusive instruction locked (EIL) 1 1 0 1 Exclusive instruction and data locked (EL) 1 1 0 0 Stale (data invalid, locks invalid) (T) 1 0 1 1 Stale (data invalid, dlock valid) (TDL) 1 1 1 0 Stale (data invalid, ilock valid) (TIL) 1 1 1 1 Stale (data invalid, locks valid) (TL)

Table 6-45. L2 cache states

#### 6.13.5 L2 state transitions

Table 6-46 lists state transitions for all e500 core-initiated transactions that change the L2 cache state.

Core-initiated transactions caused when the core executes **msync**, **mbar**, **tlbivax**, or **tlbsync** do not change the L2 cache state.

The table does not list initial L1 states for transactions that hit in the L1 (iL1 or dL1) and are not sent to the L2.

In the table, the heading 'L2 hit' indicates that the L2 provides (on a read) or captures (on a write) data for an existing line. Some entries list two final L1 states. L2 touch instructions never allocate into iL1 or dL1.

Note that if the L2 SRAM is disabled, the L2 initial and final states are always invalid and the L2 never hits. Similarly, if the L2 SRAM is in full memory-mapped SRAM mode, the L2 initial and final states are always invalid and the L2 never hits for addresses not in the memory-mapped SRAM address range. The L2 always hits for addresses in the enabled memory-mapped SRAM address ranges.

Table 6-46. State transitions due to core-initiated transactions

| Source of transaction             | Initial | states | L2<br>Hit | Final | states | Comments                                                            |
|-----------------------------------|---------|--------|-----------|-------|--------|---------------------------------------------------------------------|
|                                   | L1      | L2     |           | L1    | L2     |                                                                     |
| Cacheable instruction fetch       | iL1     | I/T    | No        | I/V   | Same   | 1                                                                   |
| icbtls_L1                         | 1       |        |           |       |        | allocated in L1                                                     |
|                                   |         | I      | No        | I/V   | Е      | L2CTL[L2DO] = 0                                                     |
| icbt_L2                           | dL1     | E/EL   | Yes       | I/V   | Same   | -                                                                   |
|                                   | I,E     |        |           |       |        |                                                                     |
|                                   |         | Т      | No        | I/V   | EL     | L2CTL[L2DO] = 0. Restore locked line in L2 with valid data from bus |
| icbtls_L2                         | dL1     | I/T    | No        | I     | Same   | L2CTL[L2DO] = 1                                                     |
|                                   | I,E     |        |           |       |        |                                                                     |
|                                   |         | Е      | Yes       | I     | I      | L2CTL[L2DO] = 1                                                     |
|                                   |         | EL     | Yes       | I     | Т      | L2CTL[L2DO] = 1                                                     |
|                                   |         | I      | No        | I     | EL     | L2CTL[L2DO] = 0                                                     |
|                                   |         | Е      | Yes       | I     | EL     | L2CTL[L2DO] = 0                                                     |
|                                   |         | EL     | Yes       | I     | Same   | L2CTL[L2DO] = 0                                                     |
|                                   |         | Т      | No        | I     | EL     | L2CTL[L2DO] = 0. Restore locked line in L2 with valid data from bus |
| Cache-inhibited instruction fetch | N/A     | N/A    | No        | N/A   | N/A    | No L1/L2 effect                                                     |
| Cacheable load (4-state)          | dL1     | I/T    | No        | Е     | Same   | L2CTL[L2IO] = 1                                                     |
| Cacheable Iwarx (4-state)         | I       |        |           |       |        |                                                                     |
| dcbt_L1 (4-state)                 |         |        |           |       |        |                                                                     |
| dcbtls_L1 (4-state)               |         |        |           |       |        |                                                                     |
|                                   |         | Е      | Yes       | Е     | 1      | L2CTL[L2IO] = 1                                                     |
|                                   |         | EL     | Yes       | Е     | Т      | L2CTL[L2IO] = 1                                                     |
|                                   |         | I      | No        | Е     | Е      | L2CTL[L2IO] = 0                                                     |
|                                   |         | E/EL   | Yes       | Е     | Same   | L2CTL[L2IO] = 0                                                     |
|                                   |         | Т      | No        | EL    | EL     | L2CTL[L2IO] = 0. Restore locked line in L2 with valid data from bus |
| Cache-inhibited load              | N/A     | N/A    | No        | N/A   | N/A    | No L1/L2 effect                                                     |
| Cache-inhibited Iwarx             | N/A     | N/A    | No        | N/A   | N/A    | No L2 effect                                                        |
| Writeback Store                   | dL1     | I/T    | No        | М     | Same   | L2 allocates when a line is cast out of L1.                         |
|                                   | I       |        |           |       |        |                                                                     |
|                                   |         | Е      | Yes       | М     | ı      | -                                                                   |
|                                   |         | EL     | Yes       | М     | Т      | -                                                                   |
| Writeback stwcx                   | dL1     | I/T    | No        | М     | Same   | -                                                                   |
|                                   | I       |        |           |       |        |                                                                     |
|                                   |         | Е      | Yes       | М     | ı      | -                                                                   |
|                                   |         | EL     | Yes       | М     | Т      | -                                                                   |

Table 6-46. State transitions due to core-initiated transactions (continued)

| Source of transaction     | Initial | states | L2<br>Hit | Final | states | Comments                                                      |
|---------------------------|---------|--------|-----------|-------|--------|---------------------------------------------------------------|
|                           | L1      | L2     |           | L1    | L2     |                                                               |
| Cacheable load (3-state)  | dL1     | I      | No        | E/I   | Same   | L2CTL[L2IO] = 1                                               |
| Cacheable Iwarx (3-state) | 1       |        |           |       |        |                                                               |
| dcbt_L1 (3-state)         |         |        |           |       |        |                                                               |
| dcbtls_L1 (3-state)       |         |        |           |       |        |                                                               |
|                           |         | Т      | No        | E/I   | Same   | L2CTL[L2IO] = 1                                               |
|                           |         | Е      | Yes       | E/I   | ı      | L2CTL[L2IO] = 1                                               |
|                           |         | EL     | Yes       | E/I   | Т      | L2CTL[L2IO] = 1                                               |
|                           |         | I      | No        | E/I   | Е      | L2CTL[L2IO] = 0                                               |
| dcbt_L2                   | dL1     | E/EL   | Yes       | E/I   | Same   | L2CTL[L2IO] = 0                                               |
| dcbtst_L2                 | I,E     |        |           |       |        |                                                               |
|                           |         | Т      | No        | E/I   | EL     | L2CTL[L2IO] = 0. Restore locked line with valid data from bus |
| dcbtst_L1                 | dL1     | I/T    | No        | E     | Same   | -                                                             |
| dcbtstls_L1               | 1       |        |           |       |        |                                                               |
|                           |         | Е      | Yes       | Е     | ı      | -                                                             |
|                           |         | EL     | Yes       | E     | Т      | -                                                             |
| dcbtls_L2                 | dL1     | I      | No        | I     | Same   | L2CTL[L2IO] = 1                                               |
| dcbtstls_L2               | I,E     |        |           |       |        |                                                               |
|                           |         | Т      | No        | I     | Same   | L2CTL[L2IO] = 1                                               |
|                           |         | Е      | Yes       | I     | I      | L2CTL[L2IO] = 1                                               |
|                           |         | EL     | Yes       | I     | Т      | L2CTL[L2IO] = 1                                               |
|                           |         | I      | No        | I     | EL     | L2CTL[L2IO] = 0                                               |
|                           |         | E/EL   | Yes       | I     | EL     | L2CTL[L2IO] = 0                                               |
|                           |         | Т      | No        | I     | EL     | L2CTL[L2IO] = 0. Restore locked line with valid data from bus |
| Write-through store       | dL1     | I/T    | No        | same  | I      | -                                                             |
|                           | I,E,M   |        |           |       |        |                                                               |
|                           |         | E/EL   | Yes       | same  | Same   | Read-modify-write                                             |
| Cache-inhibited store     | N/A     | I/E    | No        | N/A   | I      | Invalidate line                                               |
|                           |         | EL/T   | No        | N/A   | Т      | Invalidate data, keep lock                                    |
| Cache-inhibited stwcx     | N/A     | I/E    | No        | N/A   | I      | Invalidate line                                               |
|                           |         | EL/T   | No        | N/A   | Т      | Invalidate data, keep lock                                    |
| dcblc_L2                  | dL1     | I/E    | No        | same  | Same   | -                                                             |
| icblc_L2                  | I,E,M   |        |           |       |        |                                                               |
|                           |         | EL     | No        | same  | E      | -                                                             |
|                           |         | Т      | No        | same  | I      | -                                                             |

Table 6-46. State transitions due to core-initiated transactions (continued)

| Source of transaction | Initial | L2<br>Hit | Final | states | Comments |                                                                                                  |
|-----------------------|---------|-----------|-------|--------|----------|--------------------------------------------------------------------------------------------------|
|                       | L1      | L2        |       | L1     | L2       |                                                                                                  |
| Victim castout        | dL1     | I/T       | No    | I      | Same     | L2CTL[L2IO] = 1. If software sharing cache lines between instructions and data wishes to capture |
| dcbt_L2               | M       |           |       |        |          | instruction lines in L2 with L2CTL[L2IO] = 1, it                                                 |
| icbt_L2               |         |           |       |        |          | must perform <b>dcbst</b> to flush the line out of the dL1 before fetching it into L2.           |
| dcbtst_L2             |         |           |       |        |          | before letching it into L2.                                                                      |
|                       |         | I         | No    | I      | Е        | L2CTL[L2IO] = 0                                                                                  |
|                       |         | E/EL      | No    | I      | I/T      | L2CTL[L2IO] = 1.                                                                                 |
|                       |         | ]         | Yes   | I      | Same     | L2CTL[L2IO] = 0.                                                                                 |
|                       |         | Т         | Yes   | I      | EL       | L2CTL[L2IO = 0.                                                                                  |
| dcbtls_L2             | dL1     | I         | No    | I      | EL       | An icbtls_L2 that hits modified in L1 cannot be                                                  |
| icbtls_L2             | М       |           |       |        |          | distinguished from dcbtls_L2 and sets the L2 dlock bit. If software shares cache lines between   |
| dcbtstls_L2           |         |           |       |        |          | instructions and data and wishes to set locks in L2,                                             |
|                       |         |           |       |        |          | it must perform <b>dcbst</b> to flush the line out of the dL1 before locking it in L2.           |
|                       |         | E/EL/T    | Yes   | I      | EL       | -                                                                                                |
| Snoop push            | dL1     | I/E       | No    | I/E    | I        | -                                                                                                |
|                       | М       |           |       |        |          |                                                                                                  |
|                       |         | EL/T      | No    | I/E    | Т        | Invalidate data, keep lock                                                                       |
| dcbf                  | dL1     | I/E/EL    | No    | I      | I        | -                                                                                                |
| dcbst                 | М       |           |       |        |          |                                                                                                  |
| dcbz                  | dL1     | I/E       | No    | М      | 1        | -                                                                                                |
| dcba                  | I       |           |       |        |          |                                                                                                  |
|                       |         | EL        | No    | М      | Т        | -                                                                                                |
| dcbi                  | dL1     | I/        | No    | I      | I        | -                                                                                                |
|                       | I,E,M   | E/EL/T    |       |        |          |                                                                                                  |
| dcbf                  | dL1     | I/        | No    | I      | I        | -                                                                                                |
| dcbst                 | I,E     | E/EL/T    |       |        |          |                                                                                                  |
| icbi                  | iL1     | I/        | No    | I      | I        | -                                                                                                |
|                       | I,V     | E/EL/T    |       |        |          |                                                                                                  |

Table 6-47 lists L2 cache state transitions for all system-initiated (non-core) transactions that change the L2. The transaction types and attributes listed follow MPX bus nomenclature, with the addition of write allocate (burst write with L2 cache allocation). Table 6-47 accounts for changes caused by L1 snoop pushes triggered by snoops, listed in Table 6-46.

Table 6-47. State transitions due to system-initiated transactions

| Transaction type        | wt | ci | gbl | Initial L2<br>state | Final L2 state | Comments                                                                |
|-------------------------|----|----|-----|---------------------|----------------|-------------------------------------------------------------------------|
| Clean                   | х  | х  | 0   | I/E/EL/T            | Same           | -                                                                       |
| IKill                   |    |    |     |                     |                |                                                                         |
| Flush                   | х  | х  | 0   | I/E/EL/T            | I              | -                                                                       |
| Write allocate          | х  | 1  | 0   | I/E/EL/T            | EL             | Allocate and lock regardless of cache external write (CEW) window       |
|                         | х  | 1  | 0   | I/E                 | E              | Allocate regardless of CEW window                                       |
|                         |    |    |     | EL/T                | EL             | -                                                                       |
|                         | х  | 0  | 0   | I/E                 | I              | No allocate if cache-inhibited                                          |
|                         |    |    |     | EL/T                | Т              | Invalidate data, keep lock                                              |
| WWK                     | х  | 1  | 0   | I/E/EL/T            | I              | Miss in cache external write windows                                    |
| 32-byte WWF             |    |    |     |                     |                |                                                                         |
| 32-byte WWF atomic      |    |    |     |                     |                |                                                                         |
|                         |    |    |     | I                   | E/EL           | Hit in cache external write window                                      |
|                         |    |    |     | EL                  | Same           | Hit in cache external write window                                      |
|                         |    |    |     | E                   | E/EL           | Hit in cache external write window                                      |
|                         |    |    |     | Т                   | EL             | Hit in cache external write window                                      |
|                         | х  | 0  | 0   | I/E                 | I              | Invalidate line                                                         |
|                         |    |    |     | EL/T                | Т              | Invalidate data, keep lock                                              |
| < 32-byte WWF           | х  | 1  | 0   | I/E                 | I              | Miss in cache external write windows                                    |
| < 32-byte WWF atomic    |    |    |     |                     |                |                                                                         |
|                         |    |    |     | EL/T                | Т              | Miss in cache external write windows.                                   |
|                         |    |    |     | I/T                 | Same           | Hit in CEW window but need burst data                                   |
|                         |    |    |     | EL                  | Same           | Hit in cache external write window                                      |
|                         |    |    |     | Е                   | E/EL           | Hit in cache external write window. Set lock if CEW lock attribute set. |
|                         | х  | 0  | 0   | I/E                 | I              | Invalidate line                                                         |
|                         |    |    |     | EL/T                | Т              | Invalidate data, keep lock                                              |
| Read                    | 1  | 1  | 0   | I/T                 | Same           | -                                                                       |
| Read atomic             |    |    |     |                     |                |                                                                         |
|                         |    |    |     | E                   | Same           | -                                                                       |
|                         |    |    |     | EL                  | Same           | -                                                                       |
|                         | х  | 0  | 0   | N/A                 | N/A            | No L1/L2 effect                                                         |
| RWNITC 1 1 0 1/T Same - |    | -  |     |                     |                |                                                                         |
|                         |    |    |     | E                   | Same           | -                                                                       |
|                         |    |    |     | EL                  | Same           | -                                                                       |
|                         | 0  | 1  | 0   | I                   | Same           | Read-and-clear-lock                                                     |
|                         |    |    |     | EL                  | E              | -                                                                       |
|                         |    |    |     | Т                   | I              | -                                                                       |
|                         | х  | 0  | 0   | N/A                 | N/A            | No L1/L2 effect                                                         |

Table 6-47. State transitions due to system-initiated transactions (continued)

| Transaction type | wt | ci | gbl | Initial L2<br>state | Final L2<br>state | Comments                   |
|------------------|----|----|-----|---------------------|-------------------|----------------------------|
| Kill             | х  | 1  | 0   | I/E                 | I                 | -                          |
| RWITM            |    |    |     |                     |                   |                            |
| RWITM atomic     |    |    |     |                     |                   |                            |
| RClaim           |    |    |     |                     |                   |                            |
|                  |    |    |     | EL/T                | Т                 | Invalidate data, keep lock |
|                  | х  | 0  | 0   | I/E/EL/T            | Same              | -                          |

## 6.14 Error checking and correcting (ECC)

The L2 cache supports error checking and correcting (ECC) for the data path between the core master and system memory.

It detects all double-bit errors, detects all multi-bit errors within a nibble, and corrects all single-bit errors. Other errors may be detected, but are not guaranteed to be corrected or detected. Multiple-bit errors are always reported when error reporting is enabled. When a single-bit error occurs, the single-bit error counter register is incremented, and its value compared to the single-bit error trigger register. An error is reported when these values are equal. The single-bit error registers can be programmed such that minor memory faults are corrected and ignored, but double- or multi-bit errors generate an interrupt.

The syndrome encodings for the ECC code are shown in Table 6-48 and Table 6-49.

Table 6-48. L2 cache ECC syndrome encoding

| Data |   |   |   |   |   |   |   | Data Syndrome bit |    |   |   |   |   |   |   |   |   |   |
|------|---|---|---|---|---|---|---|-------------------|----|---|---|---|---|---|---|---|---|---|
| bit  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7                 | bi | ¹ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0    | • | • |   |   |   |   |   | •                 | 32 | ! |   |   | • | • |   |   |   | • |
| 1    | • |   | • |   |   |   |   | •                 | 33 |   |   |   | • |   | • |   |   | • |
| 2    | • |   |   | • |   |   |   | •                 | 34 |   | • |   | • |   | • |   |   |   |
| 3    | • |   |   |   | • |   |   | •                 | 35 |   |   | • | • |   | • |   |   |   |
| 4    | • | • |   |   |   | • |   |                   | 36 | ; |   |   | • | • |   | • |   |   |
| 5    | • |   | • |   |   | • |   |                   | 37 | ' |   |   | • |   | • | • |   |   |
| 6    | • |   |   | • |   | • |   |                   | 38 |   | • |   | • |   | • | • |   | • |
| 7    | • |   |   |   | • | • |   |                   | 39 |   |   | • | • |   | • | • |   | • |
| 8    | • | • |   |   |   |   | • |                   | 40 |   |   |   | • | • |   |   | • |   |
| 9    | • |   | • |   |   |   | • |                   | 41 |   |   |   | • |   | • |   | • |   |
| 10   | • |   |   | • |   |   | • |                   | 42 |   | • |   | • |   | • |   | • | • |

Table 6-48. L2 cache ECC syndrome encoding (continued)

| Data |   |   |   | Syndr | ome bi | t |   |   | Data Syndrome bit |   |   |   |   |   |   |   |   |
|------|---|---|---|-------|--------|---|---|---|-------------------|---|---|---|---|---|---|---|---|
| bit  | 0 | 1 | 2 | 3     | 4      | 5 | 6 | 7 | bit               | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 11   | • |   |   |       | •      |   | • |   | 43                |   | • | • |   | • |   | • | • |
| 12   | • | • |   |       |        | • | • | • | 44                |   |   | • | • |   | • | • | • |
| 13   | • |   | • |       |        | • | • | • | 45                |   |   | • |   | • | • | • | • |
| 14   | • |   |   | •     |        | • | • | • | 46                | • |   | • |   | • | • | • |   |
| 15   | • |   |   |       | •      | • | • | • | 47                |   | • | • |   | • | • | • |   |
| 16   |   | • | • |       |        |   |   | • | 48                |   | • |   |   |   | • | • |   |
| 17   |   | • |   | •     |        |   |   | • | 49                |   |   | • |   |   | • | • |   |
| 18   |   | • |   |       | •      |   |   | • | 50                |   |   |   | • |   | • | • |   |
| 19   | • | • |   |       | •      |   |   |   | 51                | • |   |   |   |   | • | • |   |
| 20   |   | • | • |       |        | • |   |   | 52                |   | • |   |   |   | • |   | • |
| 21   |   | • |   | •     |        | • |   |   | 53                |   |   | • |   |   | • |   | • |
| 22   |   | • |   |       | •      | • |   |   | 54                |   |   |   | • |   | • |   | • |
| 23   | • | • |   |       | •      | • |   | • | 55                | • |   |   |   |   | • |   | • |
| 24   |   | • | • |       |        |   | • |   | 56                |   | • |   |   |   |   | • | • |
| 25   |   | • |   | •     |        |   | • |   | 57                |   |   | • |   |   |   | • | • |
| 26   |   | • |   |       | •      |   | • |   | 58                |   |   |   | • |   |   | • | • |
| 27   | • | • |   |       | •      |   | • | • | 59                | • |   |   |   |   |   | • | • |
| 28   |   | • | • |       |        | • | • | • | 60                |   |   |   | • | • |   | • |   |
| 29   |   | • |   | •     |        | • | • | • | 61                | • |   |   | • | • |   | • | • |
| 30   |   | • |   |       | •      | • | • | • | 62                |   | • |   | • | • |   | • | • |
| 31   | • | • |   |       | •      | • | • |   | 63                |   |   | • | • | • |   | • | • |

Table 6-49. L2 cache ECC syndrome encoding (check bits)

| Check bit |   | Syndrome bit |   |   |   |   |   |   |  |  |  |  |
|-----------|---|--------------|---|---|---|---|---|---|--|--|--|--|
|           | 0 | 1            | 2 | 3 | 4 | 5 | 6 | 7 |  |  |  |  |
| 0         | • |              |   |   |   |   |   |   |  |  |  |  |
| 1         |   | •            |   |   |   |   |   |   |  |  |  |  |
| 2         |   |              | • |   |   |   |   |   |  |  |  |  |
| 3         |   |              |   | • |   |   |   |   |  |  |  |  |
| 4         |   |              |   |   | • |   |   |   |  |  |  |  |
| 5         |   |              |   |   |   | • |   |   |  |  |  |  |
| 6         |   |              |   |   |   |   | • |   |  |  |  |  |
| 7         |   |              |   |   |   |   |   | • |  |  |  |  |

# **Chapter 7 e500 Coherency Module**

The e500 coherency module (ECM) provides a flexible switching structure for routing e500- and I/O-initiated transactions to target modules on the device.

## 7.1 Introduction

The e500 coherency module (ECM) provides a flexible switching structure for routing e500- and I/O-initiated transactions to target modules on the device.

Figure 7-1 shows a high-level block diagram of the ECM.



Figure 7-1. e500 coherency module block diagram

#### 7.1.1 Overview

The ECM routes transactions initiated by the e500 cores to the appropriate target interface on the device.

In a manner analogous to a bridging router in a local area network, the ECM forwards I/O-initiated transactions that are tagged with the global attribute onto the core complex bus (CCB). This allows on-chip caches to snoop these transactions as if they were locally initiated and to take actions to maintain coherency across cacheable memory.

## 7.1.2 Features

The ECM includes these distinctive features:

- Support for two e500 cores and an L2/SRAM on the CCB, including a CCB arbiter.
- Sources a 64-bit data bus for returning read data from the ECM to the e500 cores and routing write data from the ECM to the L2/SRAM. It sinks a 128-bit data bus for receiving data from the L2/SRAM and two128-bit write data buses-one from each of the e500 cores.
- Four connection points for I/O initiating (mastering into the device) interfaces. The ECM supports five connection points for I/O targets. The DDR memory controllers, enhanced local bus, OCeaN targets, and configuration register access block all have a target port connection to the ECM.
- Split transaction support-separate address and data tenures allow for pipelining of transactions and out-of-order data tenures between initiators and targets.
- Proper ordering of I/O-initiated transactions.
- Speculative read bus for low-latency dispatch of reads to the DDR controllers.
- Low-latency paths for returning read data from DDR to the e500 cores.
- Error registers trap transactions with invalid addresses. Errors can be programmed to generate interrupts to the e500 core, as described in the following sections:
  - ECM error detect register (ECM\_EEDR)
  - ECM error enable register (ECM\_EEER)
  - ECM error attributes capture register (ECM\_EEATR)
  - ECM error low address capture register (ECM\_EELADR)
  - ECM error high address capture register (ECM\_EEHADR)
- Errors from reading I/O devices terminate with data sent to the master with a corrupt attribute. If the master is the e500 core, the ECM asserts *core\_fault\_in* to the core, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If RFXE is zero and one of these errors occurs, appropriate interrupts must be enabled to ensure that an interrupt is generated.

# 7.2 ECM memory map/register definition

The table below shows the register memory map for the ECM.

### **ECM** memory map

| Offset address (hex) | Register name                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------------------|--------------------|--------|-------------|------------------|
| 1000                 | ECM CCB address configuration register (ECM_EEBACR)  | 32                 | R/W    | 0000_0003h  | 7.2.1/254        |
| 1010                 | ECM CCB port configuration register (ECM_EEBPCR)     | 32                 | R/W    | See section | 7.2.2/255        |
| 1BF8                 | ECM IP Block Revision Register 1 (ECM_EIPBRR1)       | 32                 | R      | 0001_0000h  | 7.2.3/257        |
| 1BFC                 | ECM IP Block Revision Register 2 (ECM_EIPBRR2)       | 32                 | R      | 0000_0000h  | 7.2.4/257        |
| 1E00                 | ECM error detect register (ECM_EEDR)                 | 32                 | w1c    | 0000_0000h  | 7.2.5/258        |
| 1E08                 | ECM error enable register (ECM_EEER)                 | 32                 | R/W    | 0000_0000h  | 7.2.6/259        |
| 1E0C                 | ECM error attributes capture register (ECM_EEATR)    | 32                 | R      | 0000_0000h  | 7.2.7/260        |
| 1E10                 | ECM error low address capture register (ECM_EELADR)  | 32                 | R      | 0000_0000h  | 7.2.8/262        |
| 1E14                 | ECM error high address capture register (ECM_EEHADR) | 32                 | R      | 0000_0000h  | 7.2.9/262        |

# 7.2.1 ECM CCB address configuration register (ECM\_EEBACR)

The ECM CCB address configuration register controls arbitration and streaming policies for the CCB.





## **ECM\_EEBACR** field descriptions

| Field | Description             |   |
|-------|-------------------------|---|
| 0–27  | This field is reserved. | ĺ |
| -     | Reserved                |   |

## **ECM\_EEBACR** field descriptions (continued)

| Field                   | Description                                                                                                                                                                                                              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28<br>A STRM DIS        | Controls whether the ECM allows any streaming to occur.                                                                                                                                                                  |
|                         | 0 Streaming is enabled.                                                                                                                                                                                                  |
|                         | 1 Streaming is disabled.                                                                                                                                                                                                 |
| 29<br>CORE_STRM_<br>DIS | With A_STRM_DIS, controls whether the e500 cores can stream commands onto the CCB . A_STRM_DIS and CORE_STRM_DIS must both be cleared for the e500 cores to be enabled to stream their address tenures that they master. |
|                         | 0 Stream address tenures initiated by the e500 cores , provided A_STRM_DIS is cleared.                                                                                                                                   |
|                         | 1 Streaming of address tenures initiated by the e500 cores not allowed.                                                                                                                                                  |
| 30-31<br>A_STRM_CNT     | Stream count. Specifies the maximum number of transactions that any master can stream (issue sequentially without preemption) on the CCB following an initial transaction.                                               |
|                         | 00 Reserved                                                                                                                                                                                                              |
|                         | 01 One transaction can be streamed with the initial transaction.                                                                                                                                                         |
|                         | 10 Two transactions can be streamed with the initial transaction.                                                                                                                                                        |
|                         | 11 Three transactions can be streamed with the initial transaction. Default.                                                                                                                                             |

# 7.2.2 ECM CCB port configuration register (ECM\_EEBPCR)





### ECM memory map/register definition

# **ECM\_EEBPCR** field descriptions

| Field               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–5                 | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6<br>CPU1_EN        | CPU1 port enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                     | Controls boot holdoff mode when the device is an agent of an external host or when the other core is used to perform initialization prior to allowing this core to boot. Specifies whether the e500 core (CPU) port1 is enabled to run transactions on the CCB. The CPU boot configuration power-on reset signal (cfg_cpu1_boot) determines the initial value of this bit. If the signal is sampled as a logic 1 at the negation of reset, CPU1 is enabled to boot at the end of the POR sequence. Otherwise, CPU1 cannot fetch its boot vector until an external host or another core sets the CPU1_EN bit.            |
|                     | After this bit is set, it should not be cleared by software. It is not intended to dynamically enable and disable CPU operation. It is only intended to end boot holdoff mode. See CPU boot configuration, for more information.                                                                                                                                                                                                                                                                                                                                                                                        |
|                     | The settings are as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                     | Boot holdoff mode. CPU1 arbitration is disabled on the CCB and no bus grants are issued.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7                   | CPU1 is enabled and receives bus grants in response to bus requests for the boot vector.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7<br>CPU0_EN        | CPU 0 port enable  Controls boot holdoff mode when the device is an agent of an external host or when the other core is used to perform initialization prior to allowing this core to boot . Specifies whether the e500 core (CPU) port0 is enabled to run transactions on the CCB. The CPU boot configuration power-on reset pin (cfg_cpu0_boot) determines the initial value of this bit. If the pin is sampled as a logic 1 at the negation of reset,CPU0 is enabled to boot at the end of the POR sequence. Otherwise,CPU0 cannot fetch its boot vector until an external host or another coresets the CPU0_EN bit. |
|                     | After this bit is set, it should not be cleared by software. It is not intended to dynamically enable and disable CPU operation. It is only intended to end boot holdoff mode. See CPU boot configuration, for more information.                                                                                                                                                                                                                                                                                                                                                                                        |
|                     | The settings are as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                     | <ul> <li>Boot holdoff mode. CPU0 arbitration is disabled on the CCB and no bus grants are issued.</li> <li>CPU0 is enabled and receives bus grants in response to bus requests for the boot vector.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8–25<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 26-27<br>CPU1_PRI   | Identifies the priority level of the e500 core 1 (CPU) port . This priority level is used to determine whether a particular port's bus request can cause the CCB Arbiter to terminate another port's streaming of address tenures.                                                                                                                                                                                                                                                                                                                                                                                      |
|                     | 00 Lowest priority level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                     | 01 Second lowest priority level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                     | 10 Highest priority level 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 28                  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29<br>CPU_RD_HI_DIS | Identifies which read queue of DDR targets is assigned to the e500 core (CPU) ports' read transactions (in understressed system).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                     | <ul> <li>Read high queue (higher bandwidth DDR queue) is assigned for the e500 cores' read transactions</li> <li>Read low queue (lower bandwidth DDR queue) is assigned for the e500 cores' read transactions</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                |

## **ECM\_EEBPCR** field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30–31<br>CPU0_PRI | Specifies the priority level of the e500 core 0 (CPU) port . This priority level is used to determine whether a particular port's bus request can cause the CCB arbiter to terminate another port's streaming of address tenures.  Our Lowest priority level Second lowest priority level Highest priority level Highest priority level Reserved |

# 7.2.3 ECM IP Block Revision Register 1 (ECM\_EIPBRR1)

Address: 1000h base + BF8h offset = 1BF8h



### ECM\_EIPBRR1 field descriptions

| Field          | Description    |
|----------------|----------------|
| 0–15<br>IP_ID  | IP block ID    |
| 16–23<br>IP_MJ | Major revision |
| 24–31<br>IP_MN | Minor revision |

# 7.2.4 ECM IP Block Revision Register 2 (ECM\_EIPBRR2)

Address: 1000h base + BFCh offset = 1BFCh



### ECM\_EIPBRR2 field descriptions

| Field    | Description                      |
|----------|----------------------------------|
| 0–7<br>- | This field is reserved. Reserved |

Table continues on the next page...

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### ECM memory map/register definition

## **ECM\_EIPBRR2** field descriptions (continued)

| Field           | Description                      |
|-----------------|----------------------------------|
| 8–15<br>IP_INT  | IP block integration options     |
|                 | This field is reserved. Reserved |
| 24–31<br>IP_CFG | IP block configuration options   |

# 7.2.5 ECM error detect register (ECM\_EEDR)

Address: 1000h base + E00h offset = 1E00h



## **ECM\_EEDR** field descriptions

| Field    | Description                                                                                                                   |
|----------|-------------------------------------------------------------------------------------------------------------------------------|
| MULT FRR | Multiple error Indicates the occurrence of multiple errors of the same type. Write 1 to clear.                                |
|          | <ul><li>Multiple errors of the same type were not detected.</li><li>Multiple errors of the same type were detected.</li></ul> |

## **ECM\_EEDR** field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1–30      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31<br>LAE | Local access error Write 1 to clear. The following two cases can generate LAEs:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|           | <ul> <li>Transaction does not map to any target. In this case the ECM injects read responses (with the corrupt attribute set) and write data is dropped. Note that a read that attempts to access an unmapped target causes the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If RFXE is zero and this error occurs, EEER[LAEE] must be set to ensure that an interrupt is generated.</li> <li>Source and target IDs indicate that an OCN port initiated a transaction that targets an OCN port. This loopback behavior can result from programming errors where inbound ATMU window targets are inconsistent with targets configured in the local access windows for a given address range. For this type of LAE, the dispatch (to OCN target in this case) is not screened off; the LAE error is reported, but the transaction is still sent to its OCN target.</li> </ul> |
|           | 0 Local access error has not occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | 1 Local access error occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# 7.2.6 ECM error enable register (ECM\_EEER)

The ECM error enable register (EEER) enables the reporting of error conditions to the e500 core through the internal int interrupt signal.





## **ECM\_EEER** field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–30<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31<br>LAEE | Local access error enable  Note that a read that attempts to access an unmapped target causes the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If HID1[RFXE] is zero and this error occurs, LAEE must be set to ensure that an interrupt is generated.  0 Disable reporting local access errors as interrupts.  1 Enable reporting local access errors as interrupts. |

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 7.2.7 ECM error attributes capture register (ECM\_EEATR)





### **ECM\_EEATR** field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–2   | This field is reserved. |
| -     | Reserved                |

# **ECM\_EEATR** field descriptions (continued)

| Field           | Description                                                       |  |  |  |  |  |  |
|-----------------|-------------------------------------------------------------------|--|--|--|--|--|--|
| 3–7             | Byte count. Specifies the transaction byte count.                 |  |  |  |  |  |  |
| BYTE_CNT        | 00000 32 bytes                                                    |  |  |  |  |  |  |
|                 | 00001 1 byte                                                      |  |  |  |  |  |  |
|                 | 00010 2 bytes                                                     |  |  |  |  |  |  |
|                 | 00100 4 bytes                                                     |  |  |  |  |  |  |
|                 | 01000 8 bytes                                                     |  |  |  |  |  |  |
|                 | 10000 16 bytes                                                    |  |  |  |  |  |  |
| 8–10<br>-       | This field is reserved. Reserved                                  |  |  |  |  |  |  |
| 11–15<br>SRC_ID | Source ID. Specifies the source device mastering the transaction. |  |  |  |  |  |  |
|                 | 00000 Reserved                                                    |  |  |  |  |  |  |
|                 | 00001 PCI Express 2                                               |  |  |  |  |  |  |
|                 | 00010 PCI Express 1                                               |  |  |  |  |  |  |
|                 | 00011 Reserved                                                    |  |  |  |  |  |  |
|                 | 00100 Reserved                                                    |  |  |  |  |  |  |
|                 | 00101 USB<br>00110 Reserved                                       |  |  |  |  |  |  |
|                 | 00110 Reserved<br>00111 Security                                  |  |  |  |  |  |  |
|                 | 01000 Reserved                                                    |  |  |  |  |  |  |
|                 | 01001 Reserved                                                    |  |  |  |  |  |  |
|                 | 01010 Boot sequencer                                              |  |  |  |  |  |  |
|                 | 01011 eSDHC                                                       |  |  |  |  |  |  |
|                 | 01100 Reserved                                                    |  |  |  |  |  |  |
|                 | 01101 Reserved                                                    |  |  |  |  |  |  |
|                 | 01110 Reserved                                                    |  |  |  |  |  |  |
|                 | 01111 DMA controller                                              |  |  |  |  |  |  |
|                 | 10000 Processor 0 (instruction)                                   |  |  |  |  |  |  |
|                 | 10001 Processor 0 (data)                                          |  |  |  |  |  |  |
|                 | 10010 Processor 1 (instruction)                                   |  |  |  |  |  |  |
|                 | 10011 Processor 1 (data)                                          |  |  |  |  |  |  |
|                 | 10100 QUICC Engine                                                |  |  |  |  |  |  |
|                 | 10101 DMA                                                         |  |  |  |  |  |  |
|                 | 10110 Reserved                                                    |  |  |  |  |  |  |
|                 | 10111 System access port (SAP)                                    |  |  |  |  |  |  |
|                 | 11000 eTSEC 1<br>11001 eTSEC 2                                    |  |  |  |  |  |  |
|                 | 11010 eTSEC 2                                                     |  |  |  |  |  |  |
|                 | 11011 Reserved                                                    |  |  |  |  |  |  |
|                 | 11100 Reserved                                                    |  |  |  |  |  |  |
|                 | 11101 Reserved                                                    |  |  |  |  |  |  |
|                 | 11110 Reserved                                                    |  |  |  |  |  |  |
|                 | 11111 Reserved                                                    |  |  |  |  |  |  |
| 16<br>-         | This field is reserved. Reserved                                  |  |  |  |  |  |  |

## **ECM\_EEATR** field descriptions (continued)

| Field      | Description                                                                |  |  |  |  |  |
|------------|----------------------------------------------------------------------------|--|--|--|--|--|
| 17–20      | Transaction type. Defined as follows:                                      |  |  |  |  |  |
| TTYPE      | All other settings are reserved.                                           |  |  |  |  |  |
|            | 0000 Write                                                                 |  |  |  |  |  |
|            | 0010 Write with allocate                                                   |  |  |  |  |  |
|            | 0011 Write with allocate with lock                                         |  |  |  |  |  |
|            | 0100 Address only transaction                                              |  |  |  |  |  |
|            | 1000 Read                                                                  |  |  |  |  |  |
|            | 1001 Read with unlock                                                      |  |  |  |  |  |
|            | 1100 Read with clear atomic                                                |  |  |  |  |  |
|            | 1101 Read with set atomic                                                  |  |  |  |  |  |
|            | 1110 Read with decrement atomic                                            |  |  |  |  |  |
|            | 1111 Read with increment atomic                                            |  |  |  |  |  |
| 21–30<br>- | This field is reserved. Reserved                                           |  |  |  |  |  |
| 31<br>VAL  | Register data valid.                                                       |  |  |  |  |  |
|            | 0 ECM error attribute capture register does not contain valid information. |  |  |  |  |  |
|            | 1 ECM error attribute capture register contains valid information.         |  |  |  |  |  |

# 7.2.8 ECM error low address capture register (ECM\_EELADR)





## **ECM\_EELADR** field descriptions

| Field | Description                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------|
|       | Address. Specifies the lower-order 32 bits of the 36-bit address of the transaction. Qualified by EEATR[VAL]. |

# 7.2.9 ECM error high address capture register (ECM\_EEHADR)

Address: 1000h base + E14h offset = 1E14h



### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### **ECM\_EEHADR** field descriptions

| Field         | Description                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------|
| 0–27<br>-     | This field is reserved. Reserved                                                                            |
| 28–31<br>ADDR | Address. Specifies the high-order 4 bits of the 36-bit address of the transaction. Qualified by EEATR[VAL]. |

# 7.3 Functional description

The following is a general discussion of ECM operation.

### 7.3.1 I/O arbiter

Figure 7-1 shows the I/O arbiter block that manages I/O-initiated address tenure requests arriving on the request buses.

Four request buses compete for access to the ECM, which can only process one request at a time.

The ECM uses two factors to select the winning request bus: the primary factor is requested bandwidth and the secondary factor is longest waiting/least recently granted status. By default all requesters start requesting low levels of bandwidth. A starvation avoidance algorithm ensures that low bandwidth requesters make forward progress in the presence of high bandwidth requesters. The transaction from the winning request bus competes with e500 core requests for the CCB and entry into the transaction queue.

## 7.3.2 CCB arbiter

Figure 7-1 shows the CCB arbiter block coordinating the entry of new transactions into the ECM's transaction queue.

It handles arbitration for requests to use the CCB from the e500 cores and the winning request bus and consequently controls when these new transactions can enter the transaction queue.

Because the CCB bus operates most efficiently when it streams commands from one initiator, the CCB arbiter alternates grants between streams of transactions from the e500 cores and from the winner of the I/O arbiter. The length of a stream (number of back-to-back transactions) is limited by the A\_STRM\_CNT field in the EEBACR register. However, the arbiter also uses the priority of the requests to limit streaming. If the

### **Functional description**

priority of a new request is higher than that of a stream in progress, then the higher priority transaction interrupts the other stream. The priority of e500 transactions is set by the CPU[0/1]\_PRI field in EEBPCR register. Depending how the CPU\_RD\_HI\_DIS field in EEBPCR register is set, read transactions from the e500 cores are initially assigned to either the higher- or lower-bandwidth queue of the DDR target.

# 7.3.3 Transaction queue

The ECM's transaction queue performs four basic functions: arbitration across the e500 cores and I/O masters, target mapping and dispatching, enforcement of ordering, and enforcement of coherency.

The address of each transaction is compared against each local access window, and the transaction is then routed to the appropriate target interface associated with the local access window that the address hits within. Even though the CCB and ECM allow the pipelining of transactions, the address tenures of all transactions issued from I/O masters (masters other than the e500 cores) may still be ordered. For those transactions accessing address space marked as snoopable, or space that may be cached by the e500 cores, the ECM enforces coherency, snooping those transactions on the CCB, and taking castouts from the e500 cores as is necessary.

# 7.3.4 Global data multiplexor

The global data mux allows initiators of write transactions to route data to their targets and read targets to return data to the initiators.

See Figure 7-1 for an illustration of how the global data multiplexor takes data bus connections and multiplexes them onto one 128-bit global data bus.

## 7.3.5 CCB interface

This interface formats CCB address tenures for the ECM transaction queue. It also contains the queueing and buffering needed to manage outstanding CCB data tenures.

The buffers receive e500 core-initiated write and I/O-initiated read data (that hit in the L2/SRAM module) from the e500 write (128-bit wide) and read (128-bit wide) data buses and route them through the global data mux to the global data bus. The buffers also receive e500 core-initiated read and I/O-initiated write data (that hit in the L2/SRAM module) from the global data bus and forward them onto the CCB data bus (64 bits). Figure 7-1 shows the CCB interface for both CCB address and data tenures.

# 7.4 Initialization/application information

If either e500 core is used to initialize the device, the applicable CPU boot configuration power-on reset pin should be pulled high to initially set EEBPCR[CPU0\_EN] or EEBPCR[CPU1\_EN]. See Reset, Clocking, and Initialization for more information on power-up reset initialization.

If any device other than the e500 cores is used to initialize the device, the CPU boot configuration power-on reset pins should be pulled low to initially clear EEBPCR[CPU0\_EN] and EEBPCR[CPU1\_EN]. This prevents the e500 cores from accessing any configuration registers or local memory space during initialization. However, in any such system, one step near the end of the initialization routine must set EEBPCR[CPU0\_EN] and EEBPCR[CPU1\_EN] to re-enable the e500 cores. Note that for basic functionality, EEBPCR[CPU0/1\_EN] is the only field that must be written (provided a device other than the e500 cores is used to initialize the device) in the ECM.

EEBPCR[CPU0\_PRI] and EEBPCR[CPU1\_PRI] specify the priority level associated with all e500 core initiated transactions. These values allow users running time-critical applications to adjust the average response latency of transactions initiated by the cores compared to those initiated by I/O masters. These priority levels affect whether e500 core requests can interrupt the streaming of address tenures initiated by (the ECM on behalf of) I/O masters or the other e500 core. Only transactions with a priority greater than the current CCB transaction can interrupt streaming. The higher the core's priority, the lower the average latency needed for it to obtain bus grants from the ECM because it can interrupt lower priority streaming. The default value of zero gives all core-initiated transactions the lowest priority, which prevents the cores from interrupting I/O master transaction streams.

EEBACR[A\_STRM\_CNT] allows users to balance response latency with throughput and should prove useful in tuning systems with multiple time-critical tasks. The default value of 0b11 causes the ECM to attempt to stream as many as four transactions initiated from the same CCB master. Decreasing this value decreases the maximum number of transactions that may be streamed together from any one CCB master. Decreasing this value can decrease throughput for high priority transactions, but may decrease latency for lower priority transactions from another CCB master. Note that the e500 cores must also have streaming enabled (through HID1[ASTME] in each core) for the CCB to stream.

Initialization/application information

# **Chapter 8 DDR Memory Controllers**

The fully programmable DDR SDRAM controller supports most JEDEC standard x8, x16, or x32 DDR2 and DDR3 memories available. In addition, unbuffered and registered DIMMs are supported.

## 8.1 Introduction

The fully programmable DDR SDRAM controller supports most JEDEC standard x8, x16, or x32 DDR2 and DDR3 memories available.

In addition, unbuffered and registered DIMMs are supported. However, mixing different memory types or unbuffered and registered DIMMs in the same system is not supported. Built-in error checking and correction (ECC) ensures very low bit-error rates for reliable high-frequency operation. Dynamic power management and auto-precharge modes simplify memory system design. A large set of special features, including ECC error injection, support rapid system debug.

### NOTE

In this chapter, the word 'bank' refers to a physical bank specified by a chip select; 'logical bank' refers to one of the four or eight sub-banks in each SDRAM chip. A sub-bank is specified by the 2 or 3 bits on the bank address (MBA) pins during a memory access.

The figure below is a high-level block diagram of the DDR memory controller with its associated interfaces. Functional description contains detailed figures of the controller.

#### **Features**



Figure 8-1. DDR memory controller simplified block diagram

# 8.2 Features

The DDR memory controller includes these distinctive features:

- Support for DDR2 and DDR3 SDRAM
- 32-/40-bit SDRAM data bus for DDR2 and DDR3
- Support for DRAM clocking asynchronously from the platform clock
- Programmable settings for meeting all SDRAM timing parameters
- Support for the following SDRAM configurations:
  - As many as two physical banks (chip selects), each bank independently addressable
    - 64-Mbit to 4-Gbit devices depending on internal device configuration with x8/x16/x32 data ports (no direct x4 support)
  - Unbuffered and registered DIMMs
- Chip select interleaving support
- Partial array self refresh support

- Support for data mask signals and read-modify-write for sub-double-word writes. Note that a read-modify-write sequence is only necessary when ECC is enabled.
- Support for double-bit error detection and single-bit error correction ECC (8-bit check word across 32-bit data)
- Support for address parity for registered DIMMs
- Open page management (dedicated entry for each logical bank)
- Automatic DRAM initialization sequence or software-controlled initialization sequence
- Automatic DRAM data initialization
- Write leveling supported for DDR3 memories
- Support for up to eight posted refreshes
- Memory controller clock frequency of two or four times the SDRAM clock with support for sleep power management
- Support for error injection

# 8.2.1 Modes of operation

The DDR memory controller supports the following modes:

- Dynamic power management mode. The DDR memory controller can reduce power consumption by negating the SDRAM CKE signal when no transactions are pending to the SDRAM.
- Auto-precharge mode. Clearing DDR\_SDRAM\_INTERVAL[BSTOPRE] causes the memory controller to issue an auto-precharge command with every read or write transaction. Auto-precharge mode can be enabled for separate chip selects by setting CSn\_CONFIG[AP\_n\_EN].

# 8.3 External signal descriptions

This section provides descriptions of the DDR memory controller's external signals.

It describes each signal's behavior when the signal is asserted or negated and when the signal is an input or an output.

# 8.3.1 Signals overview

Memory controller signals are grouped as follows:

### **External signal descriptions**

- Memory interface signals
- Clock signals

The table below shows all signals of DDR controller. The device hardware specification shows detailed multiplexing of these signal. Note that availability of all signals depends upon device configurations.

Table 8-1. DDR memory interface signal summary

| Name                       | Function/description                     |           | Pins | I/O |
|----------------------------|------------------------------------------|-----------|------|-----|
| MAPAR_ERR_B                | Address parity error                     | One       | 1    | I   |
| MAPAR_OUT                  | Address parity out                       | Zero      | 1    | 0   |
| MDQ[ 0:31 ]                | Data bus                                 | All zeros | 32   | I/O |
| MDQS[0:3]+<br>MDQS[8]      | Data strobes                             | All zeros | 5    | I/O |
| MDQS_B[0:3]+<br>MDQS_B [8] | Complement data strobes                  | All ones  | 5    | I/O |
| MECC[0:7]                  | Error checking and correcting            | All zeros | 8    | I/O |
| MCAS_B                     | Column address strobe                    | One       | 1    | 0   |
| MA[15:0]                   | Address bus                              | All zeros | 16   | 0   |
| MBA[2:0]                   | Logical bank address                     | All zeros | 3    | 0   |
| MCS_B[ 0:1]                | Chip selects                             | All ones  | 2    | 0   |
| MWE_B                      | Write enable                             | One       | 1    | 0   |
| MRAS_B                     | Row address strobe                       | One       | 1    | 0   |
| MDM[0:3]+MDM[8]            | Data mask                                | All zeros | 5    | 0   |
| MCK [0:3]                  | DRAM clock outputs                       | All zeros | 4    | 0   |
| MCK_B[0:3]                 | DRAM clock outputs (complement)          | All zeros | 4    | 0   |
| MCKE[ 0:1]                 | DRAM clock enable                        | All zeros | 2    | 0   |
| MODT[ 0:1]                 | DRAM on-die termination external control | All zeros | 2    | 0   |
| MDIC[0:1]                  | Driver impedance calibration             | 10        | 2    | I/O |

This table shows the memory address signal mappings.

Table 8-2. Memory address signal mappings

| S   | ignal name (Outputs) | JEDEC DDR DIMM signals (Inputs)        |
|-----|----------------------|----------------------------------------|
| msb | MA15                 | A15                                    |
|     | MA14                 | A14                                    |
|     | MA13                 | A13                                    |
|     | MA12                 | A12                                    |
|     | MA11                 | A11                                    |
|     | MA10                 | A10 (AP for DDR) <sup>1</sup>          |
|     | MA9                  | A9                                     |
|     | MA8                  | A8 (alternate AP for DDR) <sup>2</sup> |
|     | MA7                  | A7                                     |
|     | MA6                  | A6                                     |
|     | MA5                  | A5                                     |
|     | MA4                  | A4                                     |
|     | MA3                  | A3                                     |
|     | MA2                  | A2                                     |
|     | MA1                  | A1                                     |
| Isb | MA0                  | A0                                     |
| msb | MBA2                 | MBA2                                   |
|     | MBA1                 | MBA1                                   |
| Isb | MBA0                 | MBA0                                   |

<sup>1.</sup> Auto-precharge for DDR signaled on A10 when DDR\_SDRAM\_CFG[PCHB8] = 0

# 8.3.2 Detailed signal descriptions

The following sections describe the DDR SDRAM controller input and output signals, the meaning of their different states, and relative timing information for assertion and negation.

<sup>2.</sup> Auto-precharge for DDR signaled on A8 when DDR\_SDRAM\_CFG[PCHB8] = 1

# 8.3.2.1 Memory interface signals

This table describes the DDR controller memory interface signals.

Table 8-3. Memory interface signals-detailed signal descriptions

| Signal                    | I/O | Description                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                  |  |  |  |
|---------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MDQ[ 0:31 ]               | I/O | Data bus.                                                                                                                                                                                                                                                                                      | Both input and output signals on the DDR memory controller.                                                                                                                                                                                                                                                      |  |  |  |
|                           | 0   | As outputs for the bidirectional data bus, these signals operate as described below.                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                           |     | State meaning                                                                                                                                                                                                                                                                                  | Asserted/Negated-Represent the value of data being driven by the DDR memory controller.                                                                                                                                                                                                                          |  |  |  |
|                           |     | Timing                                                                                                                                                                                                                                                                                         | Assertion/Negation-Driven coincident with corresponding data strobes (MDQS) signal.                                                                                                                                                                                                                              |  |  |  |
|                           |     |                                                                                                                                                                                                                                                                                                | High impedance-No READ or WRITE command is in progress; data is not being driven by the memory controller or the DRAM.                                                                                                                                                                                           |  |  |  |
|                           | I   | As inputs                                                                                                                                                                                                                                                                                      | for the bidirectional data bus, these signals operate as described below.                                                                                                                                                                                                                                        |  |  |  |
|                           |     | State<br>Meaning                                                                                                                                                                                                                                                                               | Asserted/Negated-Represents the state of data being driven by the external DDR SDRAMs.                                                                                                                                                                                                                           |  |  |  |
|                           |     | Timing                                                                                                                                                                                                                                                                                         | Assertion/Negation-The DDR SDRAM drives data during a READ transaction.                                                                                                                                                                                                                                          |  |  |  |
|                           |     |                                                                                                                                                                                                                                                                                                | High impedance-No READ or WRITE command in progress; data is not being driven by the memory controller or the DRAM.                                                                                                                                                                                              |  |  |  |
| MDQS[0:3]<br>+MDQS[8]/    | I/O | Data strob                                                                                                                                                                                                                                                                                     | oes. Inputs with read data, outputs with write data. The data strobes may be single ended or l.                                                                                                                                                                                                                  |  |  |  |
| MDQS_B[0:3]<br>+MDQS_B[8] | 0   | As outputs, the data strobes are driven by the DDR memory controller during a write transmemory controller always drives these signals low unless a read has been issued and in strobes are expected. This keeps the data strobes from floating high when there are not on the DRAM interface. |                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                           | I   | State<br>Meaning                                                                                                                                                                                                                                                                               | Asserted/Negated-Driven high when positive capture data is transmitted and driven low when negative capture data is transmitted. Centered in the data "eye" for writes; coincident with the data eye for reads. Treated as a clock. Data is valid when signals toggle. See Table 8-58 for byte lane assignments. |  |  |  |
|                           |     | Timing                                                                                                                                                                                                                                                                                         | Assertion/Negation-If a WRITE command is registered at clock edge $n$ , and the latency is programmed in TIMING_CFG_2[WR_LAT] to be $m$ clocks, data strobes at the DRAM assert coincident with the data on clock edge $n + m$ . See the JEDEC DDR SDRAM specification for more information.                     |  |  |  |
|                           |     |                                                                                                                                                                                                                                                                                                | the data strobes are driven by the external DDR SDRAMs during a read transaction. The es are used by the memory controller to synchronize data latching.                                                                                                                                                         |  |  |  |
|                           |     | State<br>Meaning                                                                                                                                                                                                                                                                               | Asserted/Negated-Driven high when positive capture data is received and driven low when negative capture data is received. Centered in the data eye for writes; coincident with the data eye for reads. Treated as a clock. Data is valid when signals toggle. See Table 8-58 for byte lane assignments.         |  |  |  |
|                           |     | Timing                                                                                                                                                                                                                                                                                         | Assertion/Negation-If a READ command is registered at clock edge $n$ , and the latency is programmed in TIMING_CFG_1[CASLAT] to be $m$ clocks, data strobes at the DRAM assert coincident with the data on clock edge $n + m$ . See the JEDEC DDR SDRAM specification for more information.                      |  |  |  |

Table 8-3. Memory interface signals-detailed signal descriptions (continued)

| Signal    | I/O   |                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MECC[0:7] | I/O   |                                      | king and correcting codes. Input and output signals for the DDR controller's bidirectional MECC[0:5] function in both normal and debug modes.                                                                                                                                                                                                                                                                   |
|           | 0     | writes. As                           | mode outputs, the ECC signals represent the state of ECC driven by the DDR controller on debug mode outputs MECC[0:5] provide source ID and data-valid information. See Error and correcting (ECC) and Debug information on debug pins for more details.                                                                                                                                                        |
|           |       | State<br>Meaning                     | Asserted/Negated-Represents the state of ECC being driven by the DDR controller on writes.                                                                                                                                                                                                                                                                                                                      |
|           |       | Timing                               | Assertion/Negation-Same timing as MDQ                                                                                                                                                                                                                                                                                                                                                                           |
|           |       |                                      | High impedance-Same timing as MDQ                                                                                                                                                                                                                                                                                                                                                                               |
|           | I     | As inputs,                           | the ECC signals represent the state of ECC driven by the SDRAM devices on reads.                                                                                                                                                                                                                                                                                                                                |
|           |       | State<br>Meaning                     | Asserted/Negated-Represents the state of ECC being driven by the DDR SDRAMs on reads.                                                                                                                                                                                                                                                                                                                           |
|           |       | Timing                               | Assertion/Negation-Same timing as MDQ                                                                                                                                                                                                                                                                                                                                                                           |
|           |       |                                      | High impedance-Same timing as MDQ                                                                                                                                                                                                                                                                                                                                                                               |
| MA[15:0]  | 0     | address b                            | bus. Memory controller outputs for the address to the DRAM. MA[15:0] carry 16 of the its for the DDR memory interface corresponding to the row and column address bits. MA0 is the address output from the memory controller.                                                                                                                                                                                   |
|           |       | State<br>Meaning                     | Asserted/Negated-Represents the address driven by the DDR memory controller. Contains different portions of the address depending on the memory size and the DRAM command being issued by the memory controller. See Table 8-4 for a complete description of the mapping of these signals.                                                                                                                      |
|           |       | Timing                               | Assertion/Negation-The address lines are only driven when the controller has a command scheduled to issue on the address/CMD bus; otherwise they will be at high-Z. It is valid when a transaction is driven to DRAM (when MCS_B <i>n</i> is active).                                                                                                                                                           |
|           |       |                                      | High impedance-When the memory controller is disabled                                                                                                                                                                                                                                                                                                                                                           |
| MBA[2:0]  | :0] O | Each SDF<br>controller'<br>MBA0, the | ank address. Outputs that drive the logical (or internal) bank address pins of the SDRAM. RAM supports four or eight addressable logical sub-banks. Bit zero of the memory is output bank address must be connected to bit zero of the SDRAM's input bank address. The least-significant bit of the three bank address signals, is asserted during the mode register and to specify the extended mode register. |
|           |       | State<br>Meaning                     | Asserted/Negated-Selects the DDR SDRAM logical (or internal) bank to be activated during the row address phase and selects the SDRAM internal bank for the read or write operation during the column address phase of the memory access. Table 8-4 describes the mapping of these signals in all cases.                                                                                                         |
|           |       | Timing                               | Assertion/Negation-Same timing as MAn                                                                                                                                                                                                                                                                                                                                                                           |
|           |       |                                      | High impedance-Same timing as MAn                                                                                                                                                                                                                                                                                                                                                                               |

### **External signal descriptions**

Table 8-3. Memory interface signals-detailed signal descriptions (continued)

| Signal      | I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                    | Description                                                                                                                                                                                                                                                                                                     |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MCAS_B      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Column address strobe. Active-low SDRAM address multiplexing signal. MCAS_B is asserted for read or write transactions and for mode register set, refresh, and precharge commands. |                                                                                                                                                                                                                                                                                                                 |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | State<br>Meaning                                                                                                                                                                   | Asserted-Indicates that a valid SDRAM column address is on the address bus for read and write transactions. See Table 8-66 for more information on the states required on MCAS_B for various other SDRAM commands.                                                                                              |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | Negated-The column address is not guaranteed to be valid.                                                                                                                                                                                                                                                       |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timing                                                                                                                                                                             | ussertion/Negation-Assertion and negation timing is directed by the values described in DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0), DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1), DDR SDRAM timing configuration 2 DDR_TIMING_CFG_2), and DDR SDRAM timing configuration 3 (DDR_TIMING_CFG_3).  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | High impedance-MCAS_B is tri-stated when memory controller is idle.                                                                                                                                                                                                                                             |  |  |  |
| MRAS_B      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                    | ess strobe. Active-low SDRAM address multiplexing signal. Asserted for activate s. In addition; used for mode register set commands and refresh commands.                                                                                                                                                       |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | State<br>Meaning                                                                                                                                                                   | Asserted-Indicates that a valid SDRAM row address is on the address bus for read and write transactions. See Table 8-66 for more information on the states required on MRAS_B for various other SDRAM commands.                                                                                                 |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | Negated-The row address is not guaranteed to be valid.                                                                                                                                                                                                                                                          |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timing                                                                                                                                                                             | Assertion/Negation-Assertion and negation timing is directed by the values described in DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0), DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1), DDR SDRAM timing configuration 2 (DDR_TIMING_CFG_2), and DDR SDRAM timing configuration 3 (DDR_TIMING_CFG_3). |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | High impedance-MRAS_B is tri-stated when memory controller is idle.                                                                                                                                                                                                                                             |  |  |  |
| MCS_B[ 0:1] | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Chip seled                                                                                                                                                                         | hip selects. Two chip selects supported by the memory controller.                                                                                                                                                                                                                                               |  |  |  |
|             | State Meaning  Meanin |                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                 |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | Negated-Indicates no SDRAM action during the current cycle.                                                                                                                                                                                                                                                     |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timing                                                                                                                                                                             | Assertion/Negation-Asserted to signal any new transaction to the SDRAM. The transaction must adhere to the timing constraints set in TIMING_CFG_0-TIMING_CFG_3.                                                                                                                                                 |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | High impedance-Always driven unless the memory controller is disabled.                                                                                                                                                                                                                                          |  |  |  |
| MWE_B       | B O Write enable. Asserted when a write transaction is issued to the SDRAM. This is also uregisters set commands and precharge commands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                 |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | State<br>Meaning                                                                                                                                                                   | Asserted-Indicates a memory write operation. See Table 8-66 for more information on the states required on MWE_B for various other SDRAM commands.                                                                                                                                                              |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                    | Negated-Indicates a memory read operation.                                                                                                                                                                                                                                                                      |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Timing                                                                                                                                                                             | Assertion/Negation-Similar timing as MRAS_B and MCAS_B. Used for write commands.                                                                                                                                                                                                                                |  |  |  |
|             | High impedance-MWE_B is tri-stated when memory controller is idle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                 |  |  |  |

Table 8-3. Memory interface signals-detailed signal descriptions (continued)

| Signal              | I/O |                                                                                                                                                                                                                                                                                                                                                                                                       | Description                                                                                                                                                                                                                                             |  |  |  |  |
|---------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| MDM[0:3]<br>+MDM[8] | 0   | DDR SDRAM data output mask. Masks unwanted bytes of data transferred during a write. They are needed to support sub-burst-size transactions (such as single-byte writes) on SDRAM where all I/O occurs in multi-byte bursts. MDM[0] corresponds to the most significant byte (MSB) and MDM[3] corresponds to the LSB, while MDM[8] corresponds to the ECC byte. Table 8-58 shows byte lane encodings. |                                                                                                                                                                                                                                                         |  |  |  |  |
|                     |     | State<br>Meaning                                                                                                                                                                                                                                                                                                                                                                                      | Asserted-Prevents writing to DDR SDRAM. Asserted when data is written to DRAM if the corresponding byte(s) should be masked for the write. Note that the MDMn signals are active-high for the DDR controller. MDMn is part of the DDR command encoding. |  |  |  |  |
|                     |     |                                                                                                                                                                                                                                                                                                                                                                                                       | Negated-Allows the corresponding byte to be read from or written to the SDRAM.                                                                                                                                                                          |  |  |  |  |
|                     |     | Timing                                                                                                                                                                                                                                                                                                                                                                                                | Assertion/Negation-Same timing as MDQx as outputs.                                                                                                                                                                                                      |  |  |  |  |
|                     |     |                                                                                                                                                                                                                                                                                                                                                                                                       | High-impedance-Always driven unless the memory controller is disabled.                                                                                                                                                                                  |  |  |  |  |
| MODT[ 0:1]          | 0   |                                                                                                                                                                                                                                                                                                                                                                                                       | rmination. Memory controller outputs for the ODT to the DRAM. MODT[ 0:1] represents the mination for the associated data, data masks, ECC, and data strobes.                                                                                            |  |  |  |  |
|                     |     | State<br>Meaning                                                                                                                                                                                                                                                                                                                                                                                      | Asserted/Negated-Represents the ODT driven by the DDR memory controller.                                                                                                                                                                                |  |  |  |  |
|                     |     | Timing                                                                                                                                                                                                                                                                                                                                                                                                | Assertion/Negation-Driven in accordance with JEDEC DRAM specifications for on-die termination timings. It is configured through the CSn_CONFIG[ODT_RD_CFG] and CSn_CONFIG[ODT_WR_CFG] fields.                                                           |  |  |  |  |
|                     |     |                                                                                                                                                                                                                                                                                                                                                                                                       | High impedance-Always driven.                                                                                                                                                                                                                           |  |  |  |  |
| MDIC[0:1]           | I/O | pulled to 0                                                                                                                                                                                                                                                                                                                                                                                           | bedance calibration. Note that the MDIC signals require the use of resistors; MDIC0 must be GND, while MDIC1 must be pulled to GV <sub>DD</sub> . See DDR Control Driver Register 1 pRCDR_1).                                                           |  |  |  |  |
|                     |     | State<br>Meaning                                                                                                                                                                                                                                                                                                                                                                                      | These pins are used for automatic calibration of the DDR IOs.                                                                                                                                                                                           |  |  |  |  |
|                     |     | Timing                                                                                                                                                                                                                                                                                                                                                                                                | These are driven for four DRAM cycles at a time while the DDR controller is executing the automatic driver compensation.                                                                                                                                |  |  |  |  |
| MAPAR_ERR_B         | I   | Address p<br>signal is a                                                                                                                                                                                                                                                                                                                                                                              | parity error. Reflects whether an address parity error has been detected by the DRAM. This ctive low.                                                                                                                                                   |  |  |  |  |
|                     |     | State                                                                                                                                                                                                                                                                                                                                                                                                 | Asserted-An error has been detected.                                                                                                                                                                                                                    |  |  |  |  |
|                     |     | Meaning                                                                                                                                                                                                                                                                                                                                                                                               | Negated-An error has not been detected.                                                                                                                                                                                                                 |  |  |  |  |
|                     |     | Timing                                                                                                                                                                                                                                                                                                                                                                                                | Assertion/Negation-are driven by the registered DIMMs one DRAM cycle after the parity bit has been driven by the memory controller. This error signal should be held valid for two DRAM cycles.                                                         |  |  |  |  |
| MAPAR_OUT_B         | 0   | and comm                                                                                                                                                                                                                                                                                                                                                                                              | parity out. Driven by the memory controller as the parity bit calculated across the address nand bits. Even parity is used, and parity is not calculated for the MCKE[ 0:1], MODT[ 0:1], B[ 0:1] signals.                                               |  |  |  |  |
| i .                 |     | State                                                                                                                                                                                                                                                                                                                                                                                                 | Asserted-The parity bit is high.                                                                                                                                                                                                                        |  |  |  |  |
|                     |     |                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                         |  |  |  |  |
|                     |     | Meaning                                                                                                                                                                                                                                                                                                                                                                                               | Negated-The parity bit is low.                                                                                                                                                                                                                          |  |  |  |  |

# 8.3.2.2 Clock interface signals

The table below contains the detailed descriptions of the clock signals of the DDR controller.

Table 8-4. Clock signals-detailed signal descriptions

| Signal      | I/O |                  | Description                                                                                                                                                   |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
|-------------|-----|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCK [0:3],  | 0   | DRAM clo         | ck outputs and their complements.                                                                                                                             |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
| MCK_B [0:3] |     | State<br>Meaning | Asserted/Negated-The JEDEC DDR SDRAM specifications require true and complement clocks. A clock edge is seen by the SDRAM when the true and complement cross. |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
|             |     | Timing           | Assertion/Negation-Timing is controlled by the DDR_CLK_CNTL register at offset 0x130.                                                                         |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
| MCKE[ 0:1]  | 0   |                  |                                                                                                                                                               | 0                                                                                                                                                                                                               | 0 | 0 | О | stop clock<br>as the cor | ble. Output signals used as the clock enables to the SDRAM. MCKE[0:1] can be negated to ing the DDR SDRAM. The MCKE signals should be connected to the same rank of memory responding MCS_B and MODT signals. For example, MCKE[0] should be connected to the cof memory as MCS_B[0] and MODT[0]. |
|             |     |                  |                                                                                                                                                               |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
|             |     |                  | Timing                                                                                                                                                        | Assertion/Negation-Asserted when DDR_SDRAM_CFG[MEM_EN] is set. Can be negated when entering dynamic power management or self refresh. Are asserted again when exiting dynamic power management or self refresh. |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |
|             |     |                  | High impedance-Always driven.                                                                                                                                 |                                                                                                                                                                                                                 |   |   |   |                          |                                                                                                                                                                                                                                                                                                   |

# 8.4 DDR memory map/register definition

The following table shows the register memory map for the DDR memory controller.

**DDR** memory map

| Offset<br>address<br>(hex) | Register name                                       | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-----------------------------------------------------|--------------------|--------|-------------|------------------|
| 2000                       | Chip select n memory bounds (DDR_CS0_BNDS)          | 32                 | R/W    | 0000_0000h  | 8.4.1/278        |
| 2008                       | Chip select n memory bounds (DDR_CS1_BNDS)          | 32                 | R/W    | 0000_0000h  | 8.4.1/278        |
| 2080                       | Chip select n configuration (DDR_CS0_CONFIG)        | 32                 | R/W    | 0000_0000h  | 8.4.2/279        |
| 2084                       | Chip select n configuration (DDR_CS1_CONFIG)        | 32                 | R/W    | 0000_0000h  | 8.4.2/279        |
| 20C0                       | Chip select n configuration 2 (DDR_CS0_CONFIG_2)    | 32                 | R/W    | 0000_0000h  | 8.4.3/281        |
| 20C4                       | Chip select n configuration 2 (DDR_CS1_CONFIG_2)    | 32                 | R/W    | 0000_0000h  | 8.4.3/281        |
| 2100                       | DDR SDRAM timing configuration 3 (DDR_TIMING_CFG_3) | 32                 | R/W    | 0000_0000h  | 8.4.4/282        |
| 2104                       | DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0) | 32                 | R/W    | 0011_0105h  | 8.4.5/284        |
| 2108                       | DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1) | 32                 | R/W    | 0000_0000h  | 8.4.6/287        |

# **DDR** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 210C                       | DDR SDRAM timing configuration 2 (DDR_TIMING_CFG_2)                  | 32                 | R/W    | 0000_0000h  | 8.4.7/291        |
| 2110                       | DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG)                  | 32                 | R/W    | 0300_0000h  | 8.4.8/295        |
| 2114                       | DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2)              | 32                 | R/W    | 0000_0000h  | 8.4.9/298        |
| 2118                       | DDR SDRAM mode configuration (DDR_DDR_SDRAM_MODE)                    | 32                 | R/W    | 0000_0000h  | 8.4.10/301       |
| 211C                       | DDR SDRAM mode configuration 2 (DDR_DDR_SDRAM_MODE_2)                | 32                 | R/W    | 0000_0000h  | 8.4.11/302       |
| 2120                       | DDR SDRAM mode control (DDR_DDR_SDRAM_MD_CNTL)                       | 32                 | R/W    | 0000_0000h  | 8.4.12/302       |
| 2124                       | DDR SDRAM interval configuration (DDR_DDR_SDRAM_INTERVAL)            | 32                 | R/W    | 0000_0000h  | 8.4.13/306       |
| 2128                       | DDR SDRAM data initialization (DDR_DDR_DATA_INIT)                    | 32                 | R/W    | 0000_0000h  | 8.4.14/306       |
| 2130                       | DDR SDRAM clock control (DDR_DDR_SDRAM_CLK_CNTL)                     | 32                 | R/W    | 0200_0000h  | 8.4.15/307       |
| 2148                       | DDR training initialization address (DDR_DDR_INIT_ADDR)              | 32                 | R/W    | 0000_0000h  | 8.4.16/308       |
| 214C                       | DDR training initialization extended address (DDR_DDR_INIT_EXT_ADDR) | 32                 | R/W    | 0000_0000h  | 8.4.17/309       |
| 2160                       | DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                  | 32                 | R/W    | 0000_0000h  | 8.4.18/310       |
| 2164                       | DDR SDRAM timing configuration 5 (DDR_TIMING_CFG_5)                  | 32                 | R/W    | 0000_0000h  | 8.4.19/313       |
| 2170                       | DDR ZQ calibration control (DDR_DDR_ZQ_CNTL)                         | 32                 | R/W    | 0000_0000h  | 8.4.20/315       |
| 2174                       | DDR write leveling control (DDR_DDR_WRLVL_CNTL)                      | 32                 | R/W    | 0000_0000h  | 8.4.21/317       |
| 217C                       | DDR Self Refresh Counter (DDR_DDR_SR_CNTR)                           | 32                 | R/W    | 0000_0000h  | 8.4.22/320       |
| 2180                       | DDR Register Control Words 1 (DDR_DDR_SDRAM_RCW_1)                   | 32                 | R/W    | 0000_0000h  | 8.4.23/321       |
| 2184                       | DDR Register Control Words 2 (DDR_DDR_SDRAM_RCW_2)                   | 32                 | R/W    | 0000_0000h  | 8.4.24/322       |
| 2190                       | DDR write leveling control 2 (DDR_DDR_WRLVL_CNTL_2)                  | 32                 | R/W    | 0000_0000h  | 8.4.25/323       |
| 2194                       | DDR write leveling control 3 (DDR_DDR_WRLVL_CNTL_3)                  | 32                 | R/W    | 0000_0000h  | 8.4.26/325       |
| 2B20                       | DDR Debug Status Register 1 (DDR_DDRDSR_1)                           | 32                 | R      | 0000_0000h  | 8.4.27/328       |
| 2B24                       | DDR Debug Status Register 2 (DDR_DDRDSR_2)                           | 32                 | R      | 0000_0000h  | 8.4.28/329       |
| 2B28                       | DDR Control Driver Register 1 (DDR_DDRCDR_1)                         | 32                 | R/W    | 0000_0000h  | 8.4.29/329       |
| 2B2C                       | DDR Control Driver Register 2 (DDR_DDRCDR_2)                         |                    | R/W    | 0000_0000h  | 8.4.30/333       |
| 2BF8                       | DDR IP block revision 1 (DDR_DDR_IP_REV1)                            | 32                 | R      | See section | 8.4.31/334       |
| 2BFC                       | DDR IP block revision 2 (DDR_DDR_IP_REV2)                            | 32                 | R      | 0000_0300h  | 8.4.32/334       |
| 2E00                       | Memory data path error injection mask high (DDR_DATA_ERR_INJECT_HI)  | 32                 | R/W    | 0000_0000h  | 8.4.33/335       |
| 2E04                       | Memory data path error injection mask low (DDR_DATA_ERR_INJECT_LO)   | 32                 | R/W    | 0000_0000h  | 8.4.34/335       |
| 2E08                       | Memory data path error injection mask ECC (DDR_ERR_INJECT)           | 32                 | R/W    | 0000_0000h  | 8.4.35/336       |

### **DDR memory map (continued)**

| Offset<br>address<br>(hex) | Register name                                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-----------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2E20                       | Memory data path read capture high (DDR_CAPTURE_DATA_HI)        | 32                 | R/W    | 0000_0000h  | 8.4.36/337       |
| 2E24                       | Memory data path read capture low (DDR_CAPTURE_DATA_LO)         | 32                 | R/W    | 0000_0000h  | 8.4.37/337       |
| 2E28                       | Memory data path read capture ECC (DDR_CAPTURE_ECC)             | 32                 | R/W    | 0000_0000h  | 8.4.38/338       |
| 2E40                       | Memory error detect (DDR_ERR_DETECT)                            | 32                 | w1c    | 0000_0000h  | 8.4.39/339       |
| 2E44                       | Memory error disable (DDR_ERR_DISABLE)                          | 32                 | R/W    | 0000_0000h  | 8.4.40/341       |
| 2E48                       | Memory error interrupt enable (DDR_ERR_INT_EN)                  | 32                 | R/W    | 0000_0000h  | 8.4.41/343       |
| 2E4C                       | Memory error attributes capture (DDR_CAPTURE_ATTRIBUTES)        | 32                 | R/W    | 0000_0000h  | 8.4.42/345       |
| 2E50                       | Memory error address capture (DDR_CAPTURE_ADDRESS)              | 32                 | R/W    | 0000_0000h  | 8.4.43/347       |
| 2E54                       | Memory error extended address capture (DDR_CAPTURE_EXT_ADDRESS) | 32                 | R/W    | 0000_0000h  | 8.4.44/347       |
| 2E58                       | Single-Bit ECC memory error management (DDR_ERR_SBE)            | 32                 | R/W    | 0000_0000h  | 8.4.45/348       |

# 8.4.1 Chip select n memory bounds (DDR\_CSn\_BNDS)

The chip select bounds registers (CS n \_BNDS) define the starting and ending address of the memory space that corresponds to the individual chip selects. Note that the size specified in CS n \_BNDS should equal the size of physical DRAM. Also, note that EA n must be greater than or equal to SA n .

If chip select interleaving is enabled, all fields in the lower interleaved chip select are used, and the other chip selects' bounds registers are unused. For example, if chip selects 0 and 1 are interleaved, all fields in CS0\_BNDS are used, and all fields in CS1\_BNDS are unused.

Address: 2000h base + 0h offset + (8d  $\times$  i), where i=0d to 1d



### DDR\_CSn\_BNDS field descriptions

| Field    | Description                      |
|----------|----------------------------------|
| 0–3<br>- | This field is reserved. Reserved |

### DDR\_CSn\_BNDS field descriptions (continued)

| Field        | Description                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------|
| 4–15<br>SAn  | Starting address for chip select (bank) $n$ . This value is compared against the 12 msbs of the 36-bit address.    |
| 16–19<br>-   | This field is reserved. Reserved                                                                                   |
| 20–31<br>EAn | Ending address for chip select (bank) <i>n</i> . This value is compared against the 12 msbs of the 36-bit address. |

# 8.4.2 Chip select n configuration (DDR\_CSn\_CONFIG)

The chip select configuration (CS n \_CONFIG) registers enable the DDR chip selects and set the number of row and column bits used for each chip select. These registers should be loaded with the correct number of row and column bits for each SDRAM. Because CS n \_CONFIG[ROW\_BITS\_CS\_n , COL\_BITS\_CS\_n ] establish address multiplexing, the user should take great care to set these values correctly.

If chip select interleaving is enabled, then all fields in the lower interleaved chip select are used, and the other registers' fields are unused, with the exception of the ODT\_RD\_CFG and ODT\_WR\_CFG fields. For example, if chip selects 0 and 1 are interleaved, all fields in CS0\_CONFIG are used, but only the ODT\_RD\_CFG and ODT\_WR\_CFG fields in CS1\_CONFIG are used.



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# DDR\_CSn\_CONFIG field descriptions

| Field               | Description                                                                                                                                                                             |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0                   | Chip select n enable                                                                                                                                                                    |  |  |
| CS_n_EN             | 0 Chip select <i>n</i> is not active                                                                                                                                                    |  |  |
|                     | 1 Chip select <i>n</i> is active and assumes the state set in CS <i>n</i> _BNDS.                                                                                                        |  |  |
| 1–7                 | This field is reserved.                                                                                                                                                                 |  |  |
| -                   | Reserved                                                                                                                                                                                |  |  |
| 8                   | Chip select <i>n</i> auto-precharge enable                                                                                                                                              |  |  |
| AP_n_EN             | O Chip select <i>n</i> is only auto-precharged if global auto-precharge mode is enabled                                                                                                 |  |  |
|                     | (DDR_SDRAM_INTERVAL[BSTOPRE] = 0).                                                                                                                                                      |  |  |
|                     | 1 Chip select <i>n</i> always issues an auto-precharge for read and write transactions.                                                                                                 |  |  |
| 9-11<br>ODT_RD_CFG  | ODT for reads configuration. Note that CAS latency plus additive latency must be at least 3 cycles for ODT_RD_CFG to be enabled. ODT should only be used with DDR2or DDR3 memories.     |  |  |
|                     | 000 Never assert ODT for reads                                                                                                                                                          |  |  |
|                     | 001 Assert ODT only during reads to CSn                                                                                                                                                 |  |  |
|                     | 010 Assert ODT only during reads to other chip selects                                                                                                                                  |  |  |
|                     | 011 Reserved                                                                                                                                                                            |  |  |
|                     | 100 Assert ODT for all reads<br>101-111 Reserved                                                                                                                                        |  |  |
| 10                  |                                                                                                                                                                                         |  |  |
| 12                  | This field is reserved. Reserved                                                                                                                                                        |  |  |
| 13–15<br>ODT_WR_CFG | ODT for writes configuration. Note that write latency plus additive latency must be at least 3 cycles for ODT _WR_CFG to be enabled. ODT should only be used with DDR2or DDR3 memories. |  |  |
|                     | 000 Never assert ODT for writes                                                                                                                                                         |  |  |
|                     | 001 Assert ODT only during writes to CS n                                                                                                                                               |  |  |
|                     | 010 Assert ODT only during writes to other chip selects                                                                                                                                 |  |  |
|                     | 011 Reserved                                                                                                                                                                            |  |  |
|                     | 100 Assert ODT for all writes 101-111 Reserved                                                                                                                                          |  |  |
| 16–17               |                                                                                                                                                                                         |  |  |
| BA_BITS_CS_n        | Number of bank bits for SDRAM on chip select $n$ . These bits correspond to the sub-bank bits driven on MBA $n$ in DDR SDRAM address multiplexing .                                     |  |  |
|                     | 00 2 logical bank bits                                                                                                                                                                  |  |  |
|                     | 01 3 logical bank bits                                                                                                                                                                  |  |  |
|                     | 10-11 Reserved                                                                                                                                                                          |  |  |
| 18–20               | This field is reserved. Reserved                                                                                                                                                        |  |  |
| 21–23               | Number of row bits for SDRAM on chip select <i>n</i> . See DDR SDRAM address multiplexing for details.                                                                                  |  |  |
| ROW_BITS_CS_        | 000 12 row bits                                                                                                                                                                         |  |  |
|                     | 001 13 row bits                                                                                                                                                                         |  |  |
|                     | 010 14 row bits                                                                                                                                                                         |  |  |
|                     | 011 15 row bits                                                                                                                                                                         |  |  |
|                     | 100 16 row bits                                                                                                                                                                         |  |  |
|                     | 101-111 Reserved                                                                                                                                                                        |  |  |
| 24–28<br>-          | This field is reserved. Reserved                                                                                                                                                        |  |  |

## DDR\_CSn\_CONFIG field descriptions (continued)

| Field         |         | Description                                                                    |
|---------------|---------|--------------------------------------------------------------------------------|
| 29–31         |         | f column bits for SDRAM on chip select n. For DDR, the decoding is as follows: |
| COL_BITS_CS_r | 000     | 8 column bits                                                                  |
|               | 001     | 9 column bits                                                                  |
|               | 010     | 10 column bits                                                                 |
|               | 011     | 11 column bits                                                                 |
|               | 100-111 | Reserved                                                                       |

# 8.4.3 Chip select n configuration 2 (DDR\_CSn\_CONFIG\_2)

The chip select configuration (CSn\_CONFIG\_2) registers enable the partial array self refresh address decode in each chip select.

If chip select interleaving is enabled, then all fields in the lower interleaved chip select are used, and the other registers' fields are unused.





### DDR\_CSn\_CONFIG\_2 field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4             | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| -               | neserveu                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5–7<br>PASR_CFG | Partial array self refresh config. Controls the bits that are placed on MA[2:0] during the write to the EMRS(2) register when the automatic hardware DRAM initialization is used (DDR_SDRAM_CFG[BI] is cleared when DDR_SDRAM_CFG[MEM_EN] is set). If this field is a non-zero value, then it overrides the least significant 3 bits in DDR_SDRAM_MODE_2[ESDMODE2] during the automatic initialization for chip select <i>n</i> . |
|                 | In addition, if a non-zero value is programmed in this field, then the address decode for chip select $n$ is optimized for partial array self refresh, as shown in DDR SDRAM address multiplexing                                                                                                                                                                                                                                 |
|                 | 000 Partial array self refresh is disabled                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | O01-111 Partial array self refresh is enabled per JEDEC specifications. Overriding the least significant 3 bits of EMRS or EMRS(2) is only supported for DDR2and DDR3 memory types.                                                                                                                                                                                                                                               |
| 8–31<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |

# 8.4.4 DDR SDRAM timing configuration 3 (DDR\_TIMING\_CFG\_3)

DDR SDRAM timing configuration register 3 sets the extended refresh recovery time, which is combined with TIMING\_CFG\_1[REFREC] to determine the full refresh recovery time.



DDR\_TIMING\_CFG\_3 field descriptions

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0–6<br>-              | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 7<br>EXT_<br>ACTTOPRE | Extended Activate to precharge interval (t <sub>RAS</sub> ). Determines the number of clock cycles from an activate command until a precharge command is allowed. This field is concatenated with TIMING_CFG_1[ACTTOPRE] to obtain a 5-bit value for the total activate to precharge. Note that a 5-bit value of 0_0000 is the same as a 5-bit value of 1_0000. Both values represent 16 cycles.  0 0 clocks 1 16 clocks                                     |  |  |  |
| 8–11<br>-             | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 12–15<br>EXT_REFREC   | Extended refresh recovery time (t $_{RFC}$ ). Controls the number of clock cycles from a refresh command until an activate command is allowed. This field is concatenated with TIMING_CFG_1[REFREC] to obtain an 8 bit value for the total refresh recovery. Note that hardware adds an additional 8 clock cycles to the final, 8 bit value of the refresh recovery. t $_{RFC}$ = {EXT_REFREC    REFREC} + 8, such that t $_{RFC}$ is calculated as follows: |  |  |  |
|                       | 0000 0 clocks<br>0001 16 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                       | 0010 32 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|                       | 0011 48 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |

# **DDR\_TIMING\_CFG\_3** field descriptions (continued)

| Field             |                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 0100 64                                                | clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 0101 80                                                | clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 0110 96                                                | clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 0111 113                                               | 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1000 12                                                | 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1001 14                                                | 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1010 16                                                | 0 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1011 170                                               | 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1100 19                                                | 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1101 20                                                | 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | _                                                      | 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1111 24                                                | 0 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16–18             |                                                        | s reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| -                 | Reserved                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19<br>EXT_CASLAT  | command<br>clock edge<br>This field is<br>Note that is | MCAS latency from READ command. Number of clock cycles between registration of a READ by the SDRAM and the availability of the first output data. If a READ command is registered at $n$ and the latency is $m$ clocks, data is available nominally coincident with clock edge $n+m$ . It is concatenated with TIMING_CFG_1[CASLAT] to obtain a 5-bit value for the total CAS latency. If this bit is set, then 8 clocks are added to the programmed value in TIMING_CFG_1[CASLAT]. |
|                   | 0 0 clock                                              | KS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                   | 1 8 clock                                              | KS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20–28<br>-        | This field is<br>Reserved                              | s reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 29–31<br>CNTL_ADJ |                                                        | ljust. Controls the amount of delay to add to the lightly loaded control signals with respect to all M address and command signals. The signals affected by this field are MODT[ 0:1 ], MCS0:1 ], [0:1 ]                                                                                                                                                                                                                                                                            |
|                   | 000                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched aligned with the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                                 |
|                   | 001                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched 1/4 DRAM cycle later than the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                    |
|                   | 010                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched 1/2 DRAM cycle later than the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                    |
|                   | 011                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched 3/4 DRAM cycles later than the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                   |
|                   | 100                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched 1 DRAM cycles later than the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                     |
|                   | 101                                                    | MODT[ 0:1 ], $\overline{\text{MCS}}$ [ 0:1 ], and MCKE[ 0:1 ] are launched 5/4 DRAM cycles later than the other DRAM address and control signals.                                                                                                                                                                                                                                                                                                                                   |
|                   | 110-111                                                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# 8.4.5 DDR SDRAM timing configuration 0 (DDR\_TIMING\_CFG\_0)

DDR SDRAM timing configuration register 0 sets the number of clock cycles between various SDRAM control commands.





DDR\_TIMING\_CFG\_0 field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1<br>RWT | Read-to-write turnaround $\overline{(t_{RTW})}$ . Specifies how many extra cycles are added between a read to write turnaround. If 0 clocks is chosen, then the DDR controller uses a fixed number based on the CAS latency and write latency. Choosing a value other than 0 adds extra cycles past this default calculation. As a default the DDR controller determines the read-to-write turnaround as CL - WL + BL $\div$ 2 + 2. In this equation, CL is the CAS latency rounded up to the next integer, WL is the programmed write latency, and BL is the burst length. |
|            | 00 0 clocks<br>01 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|            | 10 2 clocks<br>11 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2–3<br>WRT | Write-to-read turnaround. Specifies how many extra cycles are added between a write to read turnaround. If 0 clocks is chosen, then the DDR controller uses a fixed number based on the, read latency, and write latency. Choosing a value other than 0 adds extra cycles past this default calculation. As a default, the DDR controller determines the write-to-read turnaround as WL - CL + BL $\div$ 2 + 1. In this equation, CL is                                                                                                                                     |

# **DDR\_TIMING\_CFG\_0** field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                 |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | the CAS latency rounded down to the next integer, WL is the programmed write latency, and BL is the                                                                                                                                         |
|                      | burst length.                                                                                                                                                                                                                               |
|                      | 00 0 clocks                                                                                                                                                                                                                                 |
|                      | 01 1 clock                                                                                                                                                                                                                                  |
|                      | 10 2 clocks                                                                                                                                                                                                                                 |
|                      | 11 3 clocks                                                                                                                                                                                                                                 |
| 4.5                  |                                                                                                                                                                                                                                             |
| 4–5<br>RRT           | Read-to-read turnaround. Specifies how many extra cycles are added between reads to different chip selects. As a default, 3 cycles are required between read commands to different chip selects. Extra cycles may be added with this field. |
|                      | NOTE: If 8-beat bursts are enabled, then 5 cycles are the default.Note that DDR2 does not support 8-beat bursts.                                                                                                                            |
|                      | 00 0 clocks                                                                                                                                                                                                                                 |
|                      | 01 1 clock                                                                                                                                                                                                                                  |
|                      | 10 2 clocks                                                                                                                                                                                                                                 |
|                      | 11 3 clocks                                                                                                                                                                                                                                 |
| 6–7                  | Write-to-write turnaround. Specifies how many extra cycles are added between writes to different chip                                                                                                                                       |
| WWT                  | selects. As a default, 2 cycles are required between write commands to different chip selects. Extra cycles may be added with this field.                                                                                                   |
|                      | NOTE: If 8-beat bursts are enabled, then 4 cycles are the default. Note that DDR2 does not support 8-beat bursts.                                                                                                                           |
|                      | 00 0 clocks                                                                                                                                                                                                                                 |
|                      | 01 1 clock                                                                                                                                                                                                                                  |
|                      | 10 2 clocks                                                                                                                                                                                                                                 |
|                      | 11 3 clocks                                                                                                                                                                                                                                 |
| 8                    | This field is reserved.                                                                                                                                                                                                                     |
| -                    | Reserved                                                                                                                                                                                                                                    |
| 9-11<br>ACT_PD_EXIT  | Active powerdown exit timing ( DDR2: $t_{XARD}$ and $t_{XARDS}$ and DDR3: $t_{XP}$ ). Specifies how many clock cycles to wait after exiting active powerdown before issuing any command.                                                    |
|                      | 000 Reserved                                                                                                                                                                                                                                |
|                      | 001 2 clocks                                                                                                                                                                                                                                |
|                      | 010 3 clocks                                                                                                                                                                                                                                |
|                      | 011 4 clocks                                                                                                                                                                                                                                |
|                      | 100 5 clocks                                                                                                                                                                                                                                |
|                      | 101 6 clocks                                                                                                                                                                                                                                |
|                      | 110 7 clocks                                                                                                                                                                                                                                |
|                      | 111 8 clocks                                                                                                                                                                                                                                |
| 12-15<br>PRE_PD_EXIT | Precharge powerdown exit timing (t $_{\rm XP}$ ). Specifies how many clock cycles to wait after exiting precharge powerdown before issuing any command.                                                                                     |
|                      | 0000 Reserved                                                                                                                                                                                                                               |
|                      | 0001 2 clocks                                                                                                                                                                                                                               |
|                      | 0010 3 clocks                                                                                                                                                                                                                               |
|                      | 0011 4 clocks                                                                                                                                                                                                                               |
|                      | 0100 5 clocks                                                                                                                                                                                                                               |
|                      | TO O GOORG                                                                                                                                                                                                                                  |

# **DDR\_TIMING\_CFG\_0** field descriptions (continued)

| 0101   6 clocks   0110   7 clocks   0110   7 clocks   0110   9 clocks   1000   9 clocks   1001   10 clocks   1011   11 clocks   1011   12 clocks   1110   12 clocks   1110   13 clocks   1111   15 clock   1111   15 clocks   1101   15 clocks   110 | Field | Description    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------|
| 0111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | 0101 6 clocks  |
| 1000    9 clocks   1001    10 clocks   1001    10 clocks   1011    12 clocks   1011    12 clocks   1010    13 clocks   1101    15 clocks   1110    15 clocks   1110    15 clocks   1111    16 clocks   1110    12 clocks   1101    12 clocks   1101    12 clocks   1101    12 clocks   1101    13 clocks   1101    14 clocks   1101    14 clocks   1101    15 clocks   1101  |       | 0110 7 clocks  |
| 1001   10 clocks   1010   11 clocks   1011   12 clocks   1100   13 clocks   1100   13 clocks   1101   14 clocks   1110   15 clocks   1111   16 clocks   107 powerdown exit timing ( DDR2: t ANDD, DDR3: set to 1). Specifies how many clocks must pass after exiting powerdown before ODT may be asserted.    ODT_PD_EXIT must be greater than TIMING_CFG_5[RODT_ON] when using RODT_ON overrides and must be greater than TIMING_CFG_5[WODT_ON] when using WODT_ON overrides and must be greater than TIMING_CFG_5[WODT_ON] when using WODT_ON overrides.    ODI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       | 0111 8 clocks  |
| 1010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | 1000 9 clocks  |
| 1011   12 clocks   1100   13 clocks   1101   14 clocks   1110   15 clocks   1111   15 clocks   1101   13 clocks   1101   15 clocks   1101   1101   1101   1101   1101   1101   1101   1101   1101   1101   1101   1101   110 |       | 1001 10 clocks |
| 1100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                |
| 1101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                |
| 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                |
| 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                |
| This field is reserved.   Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                |
| ODT powerdown exit timing ( DDR2: t AXPD , DDR3 : set to 1). Specifies how many clocks must pass after exiting powerdown before ODT may be asserted.    ODT_PD_EXIT must be greater than TIMING_CFG_5[RODT_ON] when using RODT_ON overrides and must be greater than TIMING_CFG_5[WODT_ON] when using WODT_ON overrides.    O000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10.10 |                |
| ODT_PD_EXIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 16–19 |                |
| must be greater than TIMING_CFG_5[WODT_ON] when using WODT_ON overrides.  0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                |
| 0001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                |
| 0001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | 0000 0 clock   |
| 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1001 10 clocks 1001 12 clocks 1100 12 clocks 1100 12 clocks 1110 13 clocks 1110 14 clocks 1110 15 clocks 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                |
| 0011   3 clocks   0100   4 clocks   0101   5 clocks   0101   5 clocks   0111   7 clocks   0111   7 clocks   1000   8 clocks   1001   9 clocks   1011   11 clocks   1101   12 clocks   1101   13 clocks   1101   13 clocks   1111   15 clocks    |       |                |
| 0101 5 clocks 0110 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1011 11 clocks 1010 12 clocks 11100 12 clocks 11101 13 clocks 11101 14 clocks 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                |
| 0110 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1101 13 clocks 1101 13 clocks 1111 15 clocks  24–27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       | 0100 4 clocks  |
| 0111 7 clocks 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks  24–27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       | 0101 5 clocks  |
| 1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | 0110 6 clocks  |
| 1001   9 clocks   1010   10 clocks   1011   11 clocks   1100   12 clocks   1101   13 clocks   1110   14 clocks   1111   15 clocks   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111   1111    |       | 0111 7 clocks  |
| 1010   10 clocks   1011   11 clocks   1100   12 clocks   1101   13 clocks   1110   14 clocks   1111   15 c |       | 1000 8 clocks  |
| 1011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | 1001 9 clocks  |
| 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks  24–27 This field is reserved. Reserved  28–31 Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0110 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       | 1010 10 clocks |
| 1101 13 clocks 1110 14 clocks 1111 15 clocks  24–27 - This field is reserved. Reserved  28–31 Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                |
| 1110 14 clocks 1111 15 clocks  24–27 - This field is reserved.  28–31 MRS_CYC  Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                |
| 24–27 - This field is reserved. Reserved  Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                |
| 24–27 - This field is reserved. Reserved  28–31 MRS_CYC  Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |                |
| - Reserved  28–31 Mode register set cycle time (t MRD). Specifies the number of cycles that must pass after a Mode Register Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                |
| MRS_CYC Set command until any other command.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 24–27 |                |
| 0001 1 clock<br>0010 2 clocks<br>0011 3 clocks<br>0100 4 clocks<br>0101 5 clocks<br>0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |                |
| 0001 1 clock<br>0010 2 clocks<br>0011 3 clocks<br>0100 4 clocks<br>0101 5 clocks<br>0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | 0000 Reserved  |
| 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                |
| 0011 3 clocks<br>0100 4 clocks<br>0101 5 clocks<br>0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                |
| 0100 4 clocks<br>0101 5 clocks<br>0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                |
| 0101 5 clocks<br>0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                |
| 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                |
| VIII / 0100NO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | 0111 7 clocks  |

## **DDR\_TIMING\_CFG\_0** field descriptions (continued)

| Field | Description    |
|-------|----------------|
|       | 1000 8 clocks  |
|       | 1001 9 clocks  |
|       | 1010 10 clocks |
|       | 1011 11 clocks |
|       | 1100 12 clocks |
|       | 1101 13 clocks |
|       | 1110 14 clocks |
|       | 1111 15 clocks |

# 8.4.6 DDR SDRAM timing configuration 1 (DDR\_TIMING\_CFG\_1)

DDR SDRAM timing configuration register 1 sets the number of clock cycles between various SDRAM control commands.

Address: 2000h base + 108h offset = 2108h



DDR\_TIMING\_CFG\_1 field descriptions

| Field    | Description                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------|
| 0–3      | Precharge-to-activate interval (t RP). Determines the number of clock cycles from a precharge command |
| PRETOACT | until an activate or refresh command is allowed.                                                      |

Table continues on the next page...

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# DDR\_TIMING\_CFG\_1 field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 0000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 | 0010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0011 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1000 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1001 9 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1010 10 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1011 11 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1100 12 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1101 13 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1110 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4–7<br>ACTTOPRE | Activate to precharge interval (t <sub>RAS</sub> ). Determines the number of clock cycles from an activate command until a precharge command is allowed. This field is concatenated with TIMING_CFG_3[EXT_ACTTOPRE] to obtain a 5-bit value for the total activate to precharge time. Note that the decode of 0000-0011 is equal to 16-19 clocks when TIMING_CFG_3[EXT_ACTTOPRE] = 0, but it is equal to 0-3 clocks when TIMING_CFG_3[EXT_ACTTOPRE] = 1. |
|                 | 0000 16 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 0001 17 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 0010 18 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 0011 19 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8–11<br>ACTTORW | Activate to read/write interval for SDRAM (t $_{\rm RCD}$ ). Controls the number of clock cycles from an activate command until a read or write command is allowed.                                                                                                                                                                                                                                                                                      |
|                 | 0000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 | 0010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0011 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1000 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1001 9 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | 1010 10 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 1011 11 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# **DDR\_TIMING\_CFG\_1** field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 1101 13 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 1110 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12–15<br>CASLAT | $\overline{\text{MCAS}}$ latency from READ command. Number of clock cycles between registration of a READ command by the SDRAM and the availability of the first output data. If a READ command is registered at clock edge $n$ and the latency is $m$ clocks, data is available nominally coincident with clock edge $n+m$ . This field is concatenated with TIMING_CFG_3[EXT_CASLAT] to obtain a 5-bit value for the total CAS latency. This value must be programmed at initialization as described in DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2) . |
|                 | 0000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | 0010 1.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 0011 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0100 2.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 0101 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0110 3.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 0111 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 1000 4.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 1001 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 1010 5.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 1011 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 1100 6.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 1101 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 1110 7.5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 1111 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16–19<br>REFREC | Refresh recovery time (t $_{RFC}$ ). Controls the number of clock cycles from a refresh command until an activate command is allowed. This field is concatenated with TIMING_CFG_3[EXTREFREC] to obtain a 7-bit value for the total refresh recovery. Note that hardware adds an additional 8 clock cycles to the final, 7-bit value of the refresh recovery, such that t $_{RFC}$ is calculated as follows: t $_{RFC}$ = {EXT_REFREC   REFREC} + 8.                                                                                                                |
|                 | 0000 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0001 9 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0010 10 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 0011 11 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | <br>1111 23 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20–23           | Last data to precharge minimum interval (t <sub>WR</sub> ). Determines the number of clock cycles from the last data                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| WRREC           | associated with a write command until a precharge command is allowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 | 0000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | 0010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0011 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### DDR memory map/register definition

# DDR\_TIMING\_CFG\_1 field descriptions (continued)

| Field             | Description                                                                                                                                                                                                        |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                   | 1000 8 clocks                                                                                                                                                                                                      |  |  |
|                   | 1001 9 clocks                                                                                                                                                                                                      |  |  |
|                   | 1010 10 clocks                                                                                                                                                                                                     |  |  |
|                   | 1011 11 clocks                                                                                                                                                                                                     |  |  |
|                   | 1100 12 clocks                                                                                                                                                                                                     |  |  |
|                   | 1101 13 clocks                                                                                                                                                                                                     |  |  |
|                   | 1110 14 clocks                                                                                                                                                                                                     |  |  |
|                   | 1111 15 clocks                                                                                                                                                                                                     |  |  |
| 24                | This field is reserved. Reserved                                                                                                                                                                                   |  |  |
| 25–27<br>ACTTOACT | Activate-to-activate interval (t <sub>RRD</sub> ). Number of clock cycles from an activate command until another activate command is allowed for a different logical bank in the same physical bank (chip select). |  |  |
|                   | 000 Reserved                                                                                                                                                                                                       |  |  |
|                   | 001 1 clock                                                                                                                                                                                                        |  |  |
|                   | 010 2 clocks                                                                                                                                                                                                       |  |  |
|                   | 011 3 clocks                                                                                                                                                                                                       |  |  |
|                   | 100 4 clocks                                                                                                                                                                                                       |  |  |
|                   | 101 5 clocks                                                                                                                                                                                                       |  |  |
|                   | 110 6 clocks                                                                                                                                                                                                       |  |  |
|                   | 111 7 clocks                                                                                                                                                                                                       |  |  |
| 28<br>-           | This field is reserved. Reserved                                                                                                                                                                                   |  |  |
| 29–31<br>WRTORD   | Last write data pair to read command issue interval (t $_{ m WTR}$ ). Number of clock cycles between the last write data pair and the subsequent read command to the same physical bank.                           |  |  |
|                   | 000 Reserved                                                                                                                                                                                                       |  |  |
|                   | 001 1 clock                                                                                                                                                                                                        |  |  |
|                   | 010 2 clocks                                                                                                                                                                                                       |  |  |
|                   | 011 3 clocks                                                                                                                                                                                                       |  |  |
|                   | 100 4 clocks                                                                                                                                                                                                       |  |  |
|                   | 101 5 clocks                                                                                                                                                                                                       |  |  |
|                   | 110 6 clocks                                                                                                                                                                                                       |  |  |
|                   | 111 7 clocks                                                                                                                                                                                                       |  |  |

# 8.4.7 DDR SDRAM timing configuration 2 (DDR\_TIMING\_CFG\_2)

DDR SDRAM timing configuration 2 sets the clock delay to data for writes.





# DDR\_TIMING\_CFG\_2 field descriptions

| Field      | Description                                                                                                                                                                                                                                                    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3        | Additive latency. The additive latency must be set to a value less than TIMING_CFG_1[ACTTORW].                                                                                                                                                                 |
| ADD_LAT    | (DDR2-specific)                                                                                                                                                                                                                                                |
|            | 0000 0 clocks                                                                                                                                                                                                                                                  |
|            | 0001 1 clock                                                                                                                                                                                                                                                   |
|            | 0010 2 clocks                                                                                                                                                                                                                                                  |
|            |                                                                                                                                                                                                                                                                |
|            | 0011 3 clocks                                                                                                                                                                                                                                                  |
|            | 0100 4 clocks                                                                                                                                                                                                                                                  |
|            | 0101 5 clocks                                                                                                                                                                                                                                                  |
|            | 0110 6 clocks                                                                                                                                                                                                                                                  |
|            | 0111 7 clocks                                                                                                                                                                                                                                                  |
|            | 1000 8 clocks                                                                                                                                                                                                                                                  |
|            | 1001 9 clocks                                                                                                                                                                                                                                                  |
|            | 1010 10 clocks                                                                                                                                                                                                                                                 |
|            | 1011 11 clocks                                                                                                                                                                                                                                                 |
|            | 1100 12 clocks                                                                                                                                                                                                                                                 |
|            | 1101 13 clocks                                                                                                                                                                                                                                                 |
|            | 1110 14 clocks                                                                                                                                                                                                                                                 |
|            | 1111 15 clocks                                                                                                                                                                                                                                                 |
| 4–8<br>CPO | MCAS -to-preamble override. Defines the number of DRAM cycles between when a read is issued and when the corresponding DQS preamble is valid for the memory controller. For these decodings, "READ_LAT" is equal to the CAS latency plus the additive latency. |
|            | 20000 PEAR LAT. 4                                                                                                                                                                                                                                              |
|            | 00000 READ_LAT + 1                                                                                                                                                                                                                                             |
|            | 00001 Reserved                                                                                                                                                                                                                                                 |
|            | 00010 READ_LAT                                                                                                                                                                                                                                                 |
|            | 00011 READ_LAT + 1/4                                                                                                                                                                                                                                           |
|            | 00100 READ_LAT + 1/2                                                                                                                                                                                                                                           |
|            | 00101 READ_LAT + 3/4                                                                                                                                                                                                                                           |
|            | 00110 READ_LAT + 1                                                                                                                                                                                                                                             |
|            | 00111 READ_LAT + 5/4                                                                                                                                                                                                                                           |
|            | 01000 READ_LAT + 3/2                                                                                                                                                                                                                                           |
|            | 01001 READ_LAT + 7/4                                                                                                                                                                                                                                           |
|            | 01010 READ_LAT + 2                                                                                                                                                                                                                                             |
|            | 01011 READ_LAT + 9/4                                                                                                                                                                                                                                           |
|            | 01100 READ_LAT + 5/2                                                                                                                                                                                                                                           |
|            | 01101 READ_LAT + 11/4                                                                                                                                                                                                                                          |
|            | 01110 READ_LAT + 3                                                                                                                                                                                                                                             |
|            | 01111 READ_LAT + 13/4                                                                                                                                                                                                                                          |
|            | 10000 READ_LAT + 7/2                                                                                                                                                                                                                                           |
|            | 10001 READ_LAT + 15/4                                                                                                                                                                                                                                          |
|            | 10010 READ_LAT + 4                                                                                                                                                                                                                                             |
|            | 10011 READ_LAT + 17/4                                                                                                                                                                                                                                          |
|            | 10100 READ_LAT + 9/2                                                                                                                                                                                                                                           |
|            | 10101 READ_LAT + 19/4                                                                                                                                                                                                                                          |
|            | 10110 READ_LAT + 5                                                                                                                                                                                                                                             |
|            | 10111 READ_LAT + 21/4                                                                                                                                                                                                                                          |
|            | 11000 READ_LAT + 11/2                                                                                                                                                                                                                                          |

# **DDR\_TIMING\_CFG\_2** field descriptions (continued)

| 11001 READ_LAT + 23/4     11010 READ_LAT + 25/4     11101 READ_LAT + 25/4     11101 READ_LAT + 27/4     11110 READ_LAT + 27/4     11111 Automatic Calibration (recommended)     9-12 Write latency, Note that the total write latency for DDR2/ DDR3 is equal to WR_LAT + ADD_LAT. If a write latency of 1 is desired, then the additive latency must also be set to at least 1 cycle.     0000 Reserved     0001 2 clocks     0010 2 clocks     0010 3 clocks     0101 5 clocks     0101 6 clocks     0101 7 clocks     0101 1 clocks     1001 1 clocks     1001 1 clocks     1010 1 clocks     1011 1 cl   | Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            | 11001 READ_LAT + 23/4                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            | 11010 READ_LAT + 6                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11101 READ_LAT + 27/4 11110 READ_LAT + 7 11111 Automatic Calibration (recommended)  9-12 WR_LAT Write latency. Note that the total write latency for DDR2/DDR3 is equal to WR_LAT + ADD_LAT. If a write latency of 1 is desired, then the additive latency must also be set to at least 1 cycle.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0101 5 clocks 0101 6 clocks 0101 7 clocks 1000 8 clocks 1001 1 rolocks 1001 1 clocks 1100 12 clocks 1101 13 clocks 1110 13 clocks 1111 15 clocks 1110 14 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 17 cloc |            | 11011 READ_LAT + 25/4                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11110 READ_LAT + 7 111111 Automatic Calibration (recommended)  9-12 WR_LAT Write latency. Note that the total write latency for DDR2/ DDR3 is equal to WR_LAT + ADD_LAT. If a write latency of 1 is desired, then the additive latency must also be set to at least 1 cycle.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0110 6 clocks 0111 7 clocks 1000 8 clocks 1010 19 clocks 1001 9 clocks 1001 11 clocks 1001 12 clocks 1100 12 clocks 1101 13 clocks 1110 13 clocks 1110 13 clocks 1111 15 clocks 1110 13 clocks 1111 15 clocks 1111 5 clo |            | 11100 READ_LAT +13/2                                                                                                                                                                                                                                                                                                                                                                                                    |
| ### Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            | 11101 READ_LAT + 27/4                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9–12 WR_LAT  Write latency. Note that the total write latency for DDR2/ DDR3 is equal to WR_LAT + ADD_LAT. If a write latency of 1 is desired, then the additive latency must also be set to at least 1 cycle.  0000 Reserved 0001 1 clock 0010 2 clocks 0011 3 clocks 0100 4 clocks 0110 5 clocks 0110 10 clocks 1100 19 clocks 1001 9 clocks 1101 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1110 15 clocks 1111 15 clocks 1110 12 clocks 1111 15 clocks 1110 1 clocks 1110 12 clocks 1110 13 clocks 1110 1 clocks 1110 12 clocks 1111 15 clocks 1110 12 clocks 1111 15 clocks 1110 15 clocks 1111 7 clocks 1110 15 clocks 1111 7 clocks 1110 17 clocks 1110 15 clocks 1111 7 cl |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| WR_LAT    latency of 1 is desired, then the additive latency must also be set to at least 1 cycle.    0000   Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            | 11111 Automatic Calibration (recommended)                                                                                                                                                                                                                                                                                                                                                                               |
| 0001 1 clock 0010 2 clocks 0010 3 clocks 0100 4 clocks 0101 5 clocks 0101 6 clocks 0110 7 clocks 1000 8 clocks 1001 9 clocks 1001 11 clocks 1001 12 clocks 1001 12 clocks 1001 12 clocks 1101 13 clocks 1101 13 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 3 clocks 1111 15 clocks 1111 15 clocks 1111 7 cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 001 3 cycles 100 4 cycles 101 5 cycles 101  |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0010 2 clocks 0011 3 clocks 0100 4 clocks 01010 5 clocks 0110 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1101 10 clocks 1101 12 clocks 1101 12 clocks 1101 13 clocks 1110 15 clocks 1110 15 clocks 1111 7 cloc |            | 0000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0011 3 clocks 0100 4 clocks 0101 5 clocks 0110 6 clocks 0111 7 clocks 1001 9 clocks 1001 9 clocks 1001 10 clocks 1001 12 clocks 1010 12 clocks 1101 13 clocks 1101 13 clocks 1110 14 clocks 1110 15 clocks 1111 15 clocks 1110 12 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks 1111 7 cycles  Reserved 000 Reserved 001 1 cycle 000 Reserved 001 1 cycle 001 2 cycles between read and precharge. 000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 111 7 cycles 111 7 cycles 111 7 cycles 112 WR_DATA_ DELAY  WR_DATA_ DELAY  WR_DATA_ DELAY  WR_DATA_ DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used. 000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0100 4 clocks 0101 5 clocks 0101 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1001 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1110 15 clocks 1111 15 clocks 1110 15 clocks 1110 17 clocks 1111 15 clocks 1111 17 clocks 1111 7 clocks 1111  |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0101 5 clocks 0110 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1110 14 clocks 1111 15 clocks 1111 7 cycles  Reserved  Reserv |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0110 6 clocks 0111 7 clocks 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1100 12 clocks 1110 14 clocks 1110 14 clocks 1111 15 clocks 1111 7 cycles 111 7 cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 110 7 cycles 110 6 cycles 110 7 cycles 110 6 cycles 111 7 cycles 111 7 cycles 112 Cycles 113 Cycles 114 Cycles 115 Cycles 116 Cycles 117 Cycles 117 Cycles 118 Cycles 119 Cycles 119 Cycles 110 6 cycles 110 6 cycles 110 6 cycles 111 7 cycles 110 6 cycles 111 7 cycles 111 7 cycles 112 Cycles 113 Cycles 114 Cycles 115 Cycles 116 Cycles 117 Cycles 117 Cycles 118 Cycles 119 Cycles 119 Cycles 110 6 cycles 110 7 cycles 110 6 cycles 110 7 cycles 110 7 cycles 110 7 cycles 110 8 cycles 110 9 cycles 110 9 cycles 110 10 cycles 110  |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0111 7 clocks 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1101 13 clocks 1101 13 clocks 1101 15 clocks 1111 3 clocks 1111 3 clocks 1111 7 clocks 1111 7 clocks 1111 15 clocks 1111 7 clocks 111 7  |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1000 8 clocks 1001 9 clocks 1010 10 clocks 1011 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks 1111 17 cycles 1000 Reserved 1001 1 cycle 1010 2 cycles between read and precharge.  000 Reserved 111 3 cycles 111 3 cycles 110 4 cycles 110 5 cycles 110 6 cycles 111 7 cycles 112 WR_DATA_DELAY  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments , for details. The write preamble typically its driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1001 9 clocks 1010 10 clocks 1011 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks 1111 15 clocks 1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 17 cycles between read and precharge.  100 Reserved 100 1 cycle 110 2 cycles 101 3 cycles 100 4 cycles 101 5 cycles 101 5 cycles 101 7 cycles 101 7 cycles 101 6 cycles 101 7 cycles 101 8 cycles 101 10 cycles 102 cycles 103 cycles 103 cycles 104 cycles 105 cycles 106 cycles 107 cycles 107 cycles 100 cycles |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1010 10 clocks 1011 11 clocks 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  1111 15 clocks  110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1011 11 clocks 1100 12 clocks 1110 13 clocks 1110 14 clocks 1111 15 clocks  13–15 - Reserved Res |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1100 12 clocks 1101 13 clocks 1110 14 clocks 1111 15 clocks  113–15 This field is reserved.  Reserved  Reserved  Reserved  Repeated to precharge (t RTP). For DDR2, with a non-zero ADD_LAT value, takes a minimum of ADD_LAT + t RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 111 7 cycles  110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1101 13 clocks 1110 14 clocks 1111 15 clocks  This field is reserved.  Reserved  Read to precharge (t RTP). For DDR2, with a non-zero ADD_LAT value, takes a minimum of ADD_LAT + t RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 110 5 cycles 110 6 cycles 111 7 cycles  WR_DATA_ DELAY  WR_DATA_ DELAY  WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13–15 16–18 RD_TO_PRE Reserved Reserved Reserved Reserved Reserved Reserved Read to precharge (t RTP). For DDR2, with a non-zero ADD_LAT value, takes a minimum of ADD_LAT + t RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| This field is reserved.  16–18 RD_TO_PRE  Reserved  Reserved  Read to precharge (t RTP). For DDR2, with a non-zero ADD_LAT value, takes a minimum of ADD_LAT + t RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            | 1110 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16–18 RD_TO_PRE  Read to precharge (t RTP). For DDR2, with a non-zero ADD_LAT value, takes a minimum of ADD_LAT + t RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 110 5 cycles 110 6 cycles 111 7 cycles  111 7 cycles  WR_DATA_ DELAY  WR_DATA_ DELAY  WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |            | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                          |
| RD_TO_PRE  RTP cycles between read and precharge.  000 Reserved 001 1 cycle 010 2 cycles 011 3 cycles 100 4 cycles 110 5 cycles 111 7 cycles  112 Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 13–15<br>- |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 001 1 cycle 010 2 cycles 011 3 cycles 110 4 cycles 110 5 cycles 111 7 cycles  111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            | 1 • 1111 /                                                                                                                                                                                                                                                                                                                                                                                                              |
| 001 1 cycle 010 2 cycles 011 3 cycles 110 4 cycles 110 5 cycles 111 7 cycles  111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            | 000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                            |
| 010 2 cycles 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 111 7 cycles  19–21  WR_DATA_ DELAY  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 011 3 cycles 100 4 cycles 101 5 cycles 110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 101 5 cycles 110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 110 6 cycles 111 7 cycles  Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            | 100 4 cycles                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19–21 WR_DATA_ DELAY WR_DATA_DELAY WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            | 101 5 cycles                                                                                                                                                                                                                                                                                                                                                                                                            |
| Write command to write data strobe timing adjustment. Controls the amount o delay applied to the data and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| WR_DATA_ DELAY  and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values should not be used.  000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            | 111 7 cycles                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | WR_DATA_   | and data strobes for writes. See DDR SDRAM write timing adjustments, for details. The write preamble typically is driven high for 1/2 DRAM cycle, and then it is driven low for 1/2 DRAM cycle. However, for WR_DATA_DELAY settings of 0 clocks and 1/4 clocks, the write preamble is driven low for the entire DRAM cycle. If the preamble needs to switch high first (to meet DDR3 specifications), then these values |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            | 000 0 clock delay                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### DDR memory map/register definition

# **DDR\_TIMING\_CFG\_2** field descriptions (continued)

| Field            |                     | Description                                                                                 |
|------------------|---------------------|---------------------------------------------------------------------------------------------|
|                  | 010 1/2 clock c     | lelay                                                                                       |
|                  | 011 3/4 clock c     | delay                                                                                       |
|                  | 100 1 clock de      | lay                                                                                         |
|                  | 101 5/4 clock c     | lelay                                                                                       |
|                  | 110 3/2 clock c     | lelay                                                                                       |
|                  | 111 Reserved        |                                                                                             |
| 22               | This field is reser | ved.                                                                                        |
| -                | Reserved            |                                                                                             |
| 23–25<br>CKE_PLS |                     | ulse width (t <sub>CKE</sub> ).                                                             |
|                  | 000 Reserved        |                                                                                             |
|                  | 001 1 clock         |                                                                                             |
|                  | 010 2 clocks        |                                                                                             |
|                  | 011 3 clocks        |                                                                                             |
|                  | 100 4 clocks        |                                                                                             |
|                  | 101 5 clocks        |                                                                                             |
|                  | 110 6 clocks        |                                                                                             |
|                  | 111 7 clocks        |                                                                                             |
| 26–31            | Window for four a   | activates (t <sub>FAW</sub> ). This is applied to DDR2/ DDR3 with eight logical banks only. |
| FOUR_ACT         | 000000              | Reserved                                                                                    |
|                  | 000001              | 1 cycle                                                                                     |
|                  | 000010              | 2 cycles                                                                                    |
|                  | 000011              | 3 cycles                                                                                    |
|                  | 000100              | 4 cycles                                                                                    |
|                  |                     |                                                                                             |
|                  | 011110              | 30 cycles                                                                                   |
|                  | 011111              | 31 cycles                                                                                   |
|                  | 100000              | 32 cycles                                                                                   |
|                  | 100001-111111       | Reserved                                                                                    |

<sup>1.</sup> For CPO decodings other than 00000 and 11111, READ\_LAT is rounded up to the next integer value.

# 8.4.8 DDR SDRAM control configuration (DDR\_DDR\_SDRAM\_CFG)

The DDR SDRAM control configuration register enables the interface logic and specifies certain operating features such as self refreshing, error checking and correcting, registered DIMMs, and dynamic power management.





### DDR\_DDR\_SDRAM\_CFG field descriptions

| Field       | Description                                                                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | DDR SDRAM interface logic enable.                                                                                                                                                                                                      |
| MEM_EN      | 0 SDRAM interface logic is disabled.                                                                                                                                                                                                   |
|             | 1 SDRAM interface logic is enabled. Must not be set until all other memory configuration parameters have been appropriately configured by initialization code.                                                                         |
| 1           | Self refresh enable (during sleep).                                                                                                                                                                                                    |
| SREN        | <ul> <li>SDRAM self refresh is disabled during sleep. Whenever self-refresh is disabled, the system is responsible for preserving the integrity of SDRAM during sleep.</li> <li>SDRAM self refresh is enabled during sleep.</li> </ul> |
| 2<br>ECC_EN | ECC enable. Note that non-correctable read errors may cause the assertion of <i>core_fault_in</i> , which causes the core to generate a machine check interrupt unless it is disabled (by clearing HID1[RFXE]). If                     |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# DDR\_DDR\_SDRAM\_CFG field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                 |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | RFXE is zero and this error occurs, ERR_DISABLE[MBED] must be zero, and ERR_INT_EN[MBEE] and                                                                                                                                |
|                   | ECC_EN must be one to ensure an interrupt is generated.                                                                                                                                                                     |
|                   | No ECC errors are reported. No ECC interrupts are generated.                                                                                                                                                                |
|                   | 1 ECC is enabled.                                                                                                                                                                                                           |
| 3                 | Registered DIMM enable. Specifies the type of DIMM used in the system.                                                                                                                                                      |
| RD_EN             | NOTE: RD_EN and 2T_EN must not both be set at the same time.                                                                                                                                                                |
|                   | Indicates unbuffered DIMMs.                                                                                                                                                                                                 |
|                   | 1 Indicates registered DIMMs.                                                                                                                                                                                               |
| 4                 | This field is reserved.                                                                                                                                                                                                     |
| -                 | Reserved                                                                                                                                                                                                                    |
| 5–7<br>SDRAM_TYPE | Type of SDRAM device to be used. This field is used when issuing the automatic hardware initialization sequence to DRAM through Mode Register Set and Extended Mode Register Set commands. Patterns not shown are reserved. |
|                   | 011 DDR2 SDRAM                                                                                                                                                                                                              |
|                   | 111 DDR3 SDRAM                                                                                                                                                                                                              |
| 8–9<br>-          | This field is reserved. Reserved                                                                                                                                                                                            |
| 10                | Dynamic power management mode                                                                                                                                                                                               |
| DYN_PWR           | Dynamic power management mode is disabled.                                                                                                                                                                                  |
|                   | Dynamic power management mode is disabled.  Dynamic power management mode is enabled. If there is no ongoing memory activity, the SDRAM                                                                                     |
|                   | CKE signal is negated.                                                                                                                                                                                                      |
| 11–12<br>DBW      | DRAM data bus width.                                                                                                                                                                                                        |
|                   | 00 Reserved                                                                                                                                                                                                                 |
|                   | 01 32-bit bus is used                                                                                                                                                                                                       |
|                   | 10 16-bit bus is used                                                                                                                                                                                                       |
|                   | 11 Reserved                                                                                                                                                                                                                 |
| 13                | 8-beat burst enable.                                                                                                                                                                                                        |
| 8_BE              | NOTE: DDR2 must use 4-beat bursts when using 32-bit bus mode                                                                                                                                                                |
|                   | NOTE: DDR3 must use 8-beat bursts when using 32-bit bus mode                                                                                                                                                                |
|                   | 0 4-beat bursts are used on the DRAM interface.                                                                                                                                                                             |
|                   | 1 8-beat bursts are used on the DRAM interface.                                                                                                                                                                             |
| 14                | This field is reserved. Reserved                                                                                                                                                                                            |
| 15<br>3T_EN       | Enable 3T timing. This field cannot be set if DDR_SDRAM_CFG[2T_EN] is also set. This field cannot be used with a 32-bit bus if 4-beat bursts are used.                                                                      |
|                   | 0 1T timing is enabled if 2T_EN is cleared. The DRAM command/address are held for only 1 cycle on the DRAM bus.                                                                                                             |
|                   | 1 3T timing is enabled. The DRAM command/address are held for 3 full cycles on the DRAM bus for every DRAM transaction. However, the chip select is only held for the third cycle.                                          |
| 16<br>2T_EN       | Enable 2T timing. This field should not be set if DDR_SDRAM_CFG[3T_EN] is set.                                                                                                                                              |

# DDR\_DDR\_SDRAM\_CFG field descriptions (continued)

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | NOTE: RD_EN and 2T_EN must not both be set at the same time.                                                                                                                                                                                                                                                                                                                                                               |
|                       | 0 1T timing is enabled if 3T_EN is cleared. The DRAM command/address is held for only 1 cycle on the DRAM bus.                                                                                                                                                                                                                                                                                                             |
|                       | 1 2T timing is enabled. The DRAM command/address are held for 2 full cycles on the DRAM bus for every DRAM transaction. However, the chip select is only held for the second cycle.                                                                                                                                                                                                                                        |
| 17–23<br>BA_INTLV_CTL | Bank (chip select) interleaving control. Set this field only if you wish to use bank interleaving.                                                                                                                                                                                                                                                                                                                         |
| BA_INTLV_CTL          | ( All unlisted field values are reserved.)                                                                                                                                                                                                                                                                                                                                                                                 |
|                       | 0000000 No external memory banks are interleaved                                                                                                                                                                                                                                                                                                                                                                           |
|                       | 1000000 External memory banks 0 and 1 are interleaved                                                                                                                                                                                                                                                                                                                                                                      |
| 24–25                 | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 26                    | x32 enable.                                                                                                                                                                                                                                                                                                                                                                                                                |
| x32_EN                | Either x8 or x16 discrete DRAM chips are used. In this mode, each data byte has a dedicated corresponding data strobe.                                                                                                                                                                                                                                                                                                     |
|                       | 1 x32 discrete DRAM chips are used. In this mode, DQS0 is used to capture DQ[0:31], DQS4 is used to capture DQ[32:63] and DQS8 is used to capture ECC[0:7].                                                                                                                                                                                                                                                                |
| 27<br>PCHB8           | Precharge bit 8 enable.                                                                                                                                                                                                                                                                                                                                                                                                    |
| РСПВО                 | 0 MA[10] is used to indicate the auto-precharge and precharge all commands.                                                                                                                                                                                                                                                                                                                                                |
|                       | 1 MA[8] is used to indicate the auto-precharge and precharge all commands.                                                                                                                                                                                                                                                                                                                                                 |
|                       | If x32_EN is cleared, then PCHB8 should be cleared as well .                                                                                                                                                                                                                                                                                                                                                               |
| 28                    | Global half-strength override.                                                                                                                                                                                                                                                                                                                                                                                             |
| HSE                   | Sets I/O driver impedance to half strength. This impedance is used by the MDIC, address/command, data, and clock impedance values, but only if automatic hardware calibration is disabled and the corresponding group's software override is disabled in the DDR control driver register(s) described in DDR Control Driver Register 1 (DDR_DDRCDR_1). This bit should be cleared if using automatic hardware calibration. |
|                       | 0 I/O driver impedance is configured to full strength.                                                                                                                                                                                                                                                                                                                                                                     |
|                       | 1 I/O driver impedance is configured to half strength.                                                                                                                                                                                                                                                                                                                                                                     |
| 29<br>-               | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 30<br>MEM_HALT        | DDR memory controller halt. When this bit is set, the memory controller does not accept any new data read/write transactions to DDR SDRAM until the bit is cleared again. This can be used when bypassing initialization and forcing MODE REGISTER SET commands through software.                                                                                                                                          |
|                       | 0 DDR controller accepts new transactions.                                                                                                                                                                                                                                                                                                                                                                                 |
|                       | 1 DDR controller finishes any remaining transactions, and then it remains halted until this bit is cleared by software.                                                                                                                                                                                                                                                                                                    |
| 31<br>BI              | Bypass initialization                                                                                                                                                                                                                                                                                                                                                                                                      |
|                       | 0 DDR controller cycles through initialization routine based on SDRAM_TYPE                                                                                                                                                                                                                                                                                                                                                 |
|                       | 1 Initialization routine is bypassed. Software is responsible for initializing memory through DDR_SDRAM_MODE2 register. If software is initializing memory, then the MEM_HALT bit can be set                                                                                                                                                                                                                               |
|                       | to prevent the DDR controller from issuing transactions during the initialization sequence. Note that the DDR controller does not issue a DLL reset to the DRAMs when bypassing the initialization routine, regardless of the value of DDR_SDRAM_CFG[DLL_RST_DIS]. If a DLL reset is required, then the controller should be forced to enter and exit self-refresh after the controller is enabled.                        |

### DDR\_DDR\_SDRAM\_CFG field descriptions (continued)

| Field | Description                                                                                                  |  |
|-------|--------------------------------------------------------------------------------------------------------------|--|
|       | See DDR training initialization address (DDR_DDR_INIT_ADDR) for details on avoiding ECC errors in this mode. |  |

# 8.4.9 DDR SDRAM control configuration 2 (DDR\_DDR\_SDRAM\_CFG\_2)

The DDR SDRAM control configuration register 2 provides more control configuration for the DDR controller.





DDR\_DDR\_SDRAM\_CFG\_2 field descriptions

| Field       | Description                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------|
| 0<br>FRC_SR | Force self-refresh  O DDR controller operates in normal mode.  DDR controller enters self-refresh mode. |
| 1<br>SR_IE  | Self-refresh interrupt enable                                                                           |

# DDR\_DDR\_SDRAM\_CFG\_2 field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | The DDR controller can be placed into self refresh mode by forcing the PIC to assert IRQ_OUT. This is considered a 'panic interrupt' by the DDR controller, and it enters self refresh as soon as possible. DDR_SDRAM_CFG[SREN] must also be set if the panic interrupt is used. |
|                | <ul> <li>DDR controller does not enter self-refresh mode if panic interrupt is asserted.</li> <li>DDR controller enters self-refresh mode if panic interrupt is asserted.</li> </ul>                                                                                             |
| 2              | DLL reset disable.                                                                                                                                                                                                                                                               |
| DLL_RST_DIS    | If self-refresh is to be used with DDR3, this bit should be set                                                                                                                                                                                                                  |
|                | The DDR controller typically issues a DLL reset to the DRAMs when exiting self refresh. However, this function may be disabled by setting this bit during initialization.                                                                                                        |
|                | DDR controller issues a DLL reset to the DRAMs when exiting self refresh.                                                                                                                                                                                                        |
|                | 1 DDR controller does not issue a DLL reset to the DRAMs when exiting self refresh.                                                                                                                                                                                              |
| 3 -            | This field is reserved. Reserved                                                                                                                                                                                                                                                 |
| 4–5<br>DQS_CFG | DQS configuration                                                                                                                                                                                                                                                                |
|                | 00 Reserved                                                                                                                                                                                                                                                                      |
|                | 01 Differential DQS signals are used.                                                                                                                                                                                                                                            |
|                | 10 Reserved 11 Reserved                                                                                                                                                                                                                                                          |
| 6–8            | This field is reserved.                                                                                                                                                                                                                                                          |
| -              | Reserved                                                                                                                                                                                                                                                                         |
| 9–10           | ODT configuration                                                                                                                                                                                                                                                                |
| ODT_CFG        | This field defines how ODT is driven to the on-chip IOs. See DDR Control Driver Register 1 (DDR_DDRCDR_1), which defines the termination value that is used.                                                                                                                     |
|                | 00 Never assert ODT to internal IOs                                                                                                                                                                                                                                              |
|                | 01 Assert ODT to internal IOs only during writes to DRAM                                                                                                                                                                                                                         |
|                | 10 Assert ODT to internal IOs only during reads to DRAM                                                                                                                                                                                                                          |
|                | 11 Always keep ODT asserted to internal IOs                                                                                                                                                                                                                                      |
| 11–15<br>-     | This field is reserved. Reserved.                                                                                                                                                                                                                                                |
| 16–19          | Number of posted refreshes                                                                                                                                                                                                                                                       |
| NUM_PR         | This determines how many posted refreshes, if any, can be issued at one time. Note that if posted refreshes are used, then this field, along with DDR_SDRAM_INTERVAL[REFINT], must be programmed such that the maximum t <sub>ras</sub> specification cannot be violated.        |
|                | 0000 Reserved                                                                                                                                                                                                                                                                    |
|                | 0001 1 refresh is issued at a time                                                                                                                                                                                                                                               |
|                | 0010 2 refreshes is issued at a time                                                                                                                                                                                                                                             |
|                | 0011 3 refreshes is issued at a time                                                                                                                                                                                                                                             |
|                |                                                                                                                                                                                                                                                                                  |
|                | 1000 8 refreshes is issued at a time                                                                                                                                                                                                                                             |
| 20.04          | 1001-1111 Reserved                                                                                                                                                                                                                                                               |
| 20–24          | This field is reserved. Reserved                                                                                                                                                                                                                                                 |

# DDR\_DDR\_SDRAM\_CFG\_2 field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 26      | Address Parity Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| AP_EN   | Determines whether address parity is generated and checked for the address and control signals when using registered DIMMs. If address parity is used, the MAPAR_OUT and MAPAR_ERR pins are used to drive the parity bit and to receive errors from the open-drain parity error signal. Even parity is used, and parity is generated for the MA[15:0], MBA[2:0], MRAS, MCAS, MWE signals. Parity does not generate for the MCKE[ 0:1 ], MODT[ 0:1 ], or MCS [ 0:1 ] signals. Note that address parity should not be used for non-zero values of TIMING_CFG_3[CNTL_ADJ]. |
|         | 0 Address parity is not used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         | 1 Address parity is used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27      | DRAM data initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| D_INIT  | This bit is set by software, and it is cleared by hardware. If software sets this bit before the memory controller is enabled, the controller automatically initializes DRAM after it is enabled. This bit is automatically cleared by hardware once the initialization is completed. This data initialization bit should only be set when the controller is idle.                                                                                                                                                                                                      |
|         | 0 There is not data initialization in progress, and no data initialization is scheduled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | 1 The memory controller initializes memory once it is enabled. This bit remains asserted until the initialization is complete. The value in DDR_DATA_INIT register is used to initialize memory.                                                                                                                                                                                                                                                                                                                                                                        |
| 28      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29      | Register Control Word Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RCW_EN  | If DDR3 registered DIMMs are used, it may be necessary to write the register control words before issuing commands to DRAM. If this bit is set, the controller will write the register control words after DDR_SDRAM_CFG[MEM_EN] is set, unless DDR_SDRAM_CFG[BI] is set. The register control words are written with the values in DDR_SDRAM_RCW_1 and DDR_SDRAM_RCW_2.                                                                                                                                                                                                |
|         | 0 Register control words will not be automatically written during DRAM initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | 1 Register control words are automatically written during DRAM initialization. This bit should only be set if DDR3 registered DIMMs are used, and the default settings need to be modified.                                                                                                                                                                                                                                                                                                                                                                             |
| 30<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31      | Mirrored DIMM Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MD_EN   | Some DDR3 DIMMs are mirrored, where certain MA and MBA pins are mirrored on one side of the DIMM. When this bit is set, the controller will know to swap these signals before transmitting to the DRAM. The controller will assume that CS1 and CS3 are the 'mirrored' ranks of memory. The following signals are mirrored (MBA[0] vs MBA[1]; MA[3] vs MA[4]; MA[5] vs MA[6]; MA[7] vs MA[8]).                                                                                                                                                                          |
|         | Mirrored DIMMs are not used     Mirrored DIMMs are used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# 8.4.10 DDR SDRAM mode configuration (DDR\_DDR\_SDRAM\_MODE)

The DDR SDRAM mode configuration register sets the values loaded into the DDR's mode registers.

Address: 2000h base + 118h offset = 2118h



#### DDR\_DDR\_SDRAM\_MODE field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15    | Extended SDRAM mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ESDMODE | Specifies the initial value loaded into the DDR SDRAM extended mode register. The range and meaning of legal values is specified by the DDR SDRAM manufacturer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | When this value is driven onto the address bus (during the DDR SDRAM initialization sequence), MA[0] presents the lsb of ESDMODE, which, in the big-endian convention shown in DDR SDRAM mode configuration (DDR_DDR_SDRAM_MODE), corresponds to ESDMODE[15]. The msb of the SDRAM extended mode register value must be stored at ESDMODE[0]. The value programmed into this field is also used for writing MR1 during write leveling for DDR3, although the bits specifically related to the write leveling scheme are handled automatically by the DDR controller. Even if DDR_SDRAM_CFG[BI] is set, this field is still used during write leveling. The write leveling enable bit should be cleared by software in this field. |
| 16–31   | SDRAM mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SDMODE  | Specifies the initial value loaded into the DDR SDRAM mode register. The range of legal values is specified by the DDR SDRAM manufacturer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         | When this value is driven onto the address bus (during DDR SDRAM initialization), MA[0] presents the lsb of SDMODE, which, in the big-endian convention shown in DDR SDRAM mode configuration (DDR_DDR_SDRAM_MODE), corresponds to SDMODE[15]. The msb of the SDRAM mode register value must be stored at SDMODE[0]. Because the memory controller forces SDMODE[7] to certain values depending on the state of the initialization sequence, (for resetting the SDRAM's DLL) the corresponding bits of this field are ignored by the memory controller. Note that SDMODE[7] is mapped to MA[8].                                                                                                                                   |

# 8.4.11 DDR SDRAM mode configuration 2 (DDR\_DDR\_SDRAM\_MODE\_2)

The DDR SDRAM mode 2 configuration register sets the values loaded into the DDR's extended mode 2 and 3 registers (for DDR2and DDR3).

Address: 2000h base + 11Ch offset = 211Ch

| Bit   | 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 |
|-------|---|---|---|---|---|---|----|-------|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
| R     |   |   |   |   |   |   |    | אסי   | OD | <u></u> = ດ |    |    |    |    |    |    |    |    |    |    |    |    |    | SDM   | $\sim$ | ⊏າ |    |    |    |    |    |    |
| w     |   |   |   |   |   |   | E3 | ואוטפ | UD |             |    |    |    |    |    |    |    |    |    |    |    |    | E3 | ווטוט | OD     | ∟o |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0     | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### DDR\_DDR\_SDRAM\_MODE\_2 field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0–15     | Extended SDRAM mode 2                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| ESDMODE2 | Specifies the initial value loaded into the DDR SDRAM extended 2 mode register. The range and meaning of legal values is specified by the DDR SDRAM manufacturer.                                                                                                                                                                                          |  |  |  |  |  |  |
|          | When this value is driven onto the address bus (during the DDR SDRAM initialization sequence), MA[0] presents the lsb bit of ESDMODE2, which, in the big-endian convention shown in DDR SDRAM mode configuration 2 (DDR_DDR_SDRAM_MODE_2), corresponds to ESDMODE2[15]. The msb of the SDRAM extended mode 2 register value must be stored at ESDMODE2[0]. |  |  |  |  |  |  |
| 16–31    | Extended SDRAM mode 3                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| ESDMODE3 | Specifies the initial value loaded into the DDR SDRAM extended 3 mode register. The range of legal values of legal values is specified by the DDR SDRAM manufacturer.                                                                                                                                                                                      |  |  |  |  |  |  |
|          | When this value is driven onto the address bus (during DDR SDRAM initialization), MA[0] presents the lsb of ESDMODE3, which, in the big-endian convention shown in DDR SDRAM mode configuration 2 (DDR_DDR_SDRAM_MODE_2), corresponds to ESDMODE3[15]. The msb of the SDRAM extended mode 3 register value must be stored at ESDMODE3[0].                  |  |  |  |  |  |  |

# 8.4.12 DDR SDRAM mode control (DDR\_DDR\_SDRAM\_MD\_CNTL)

The DDR SDRAM mode control register allows the user to carry out the following tasks:

- Issue a mode register set command to a particular chip select
- Issue an immediate refresh to a particular chip select
- Issue an immediate precharge or precharge all command to a particular chip select
- Force the CKE signals to a specific value

Before issuing a command via the DDR\_SDRAM\_MD\_CNTL register, the DDR interface should be idle. This can be done by setting DDR\_SDRAM\_CFG[MEM\_HALT] and disabling refreshes by clearing DDR\_INTERVAL[REFINT]. If there are memory contents that need to be preserved during this time, then software should also force any required refresh commands while DDR\_INTERVAL[REFINT] is cleared.

The following table shows how DDR\_SDRAM\_MD\_CNTL fields should be set for each of the tasks described above:

#### **NOTE**

Note that MD\_EN, SET\_REF, and SET\_PRE are mutually exclusive; only one of these fields can be set at a time.

Table 8-23. Settings of DDR\_SDRAM\_MD\_CNTL Fields

| Field    | Mode Register Set                                                          | Refresh | Precharge                                                                          | Clock Enable Signals<br>Control                                |
|----------|----------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------|----------------------------------------------------------------|
| MD_EN    | 1                                                                          | 0       | 0                                                                                  | -                                                              |
| SET_REF  | 0                                                                          | 1       | 0                                                                                  | -                                                              |
| SET_PRE  | 0                                                                          | 0       | 1                                                                                  | -                                                              |
| CS_SEL   | Chooses chip select (CS                                                    | S)      | •                                                                                  | -                                                              |
| MD_SEL   | Select mode register. See DDR SDRAM mode control (DDR_DDR_SDRAM_ MD_CNTL). | -       | Selects logical bank                                                               | -                                                              |
| MD_VALUE | Value written to mode register                                             | -       | Only bit five is significant. See DDR SDRAM mode control (DDR_DDR_SDRAM_MD_CNTL) . | -                                                              |
| CKE_CNTL | 0                                                                          | 0       | 0                                                                                  | See DDR SDRAM<br>mode control<br>(DDR_DDR_SDRAM_<br>MD_CNTL) . |

Address: 2000h base + 120h offset = 2120h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### DDR memory map/register definition



### DDR\_DDR\_SDRAM\_MD\_CNTL field descriptions

| Field  | Description                                                                                                                                                                                                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Mode enable                                                                                                                                                                                                                                                                                 |
| MD_EN  | Setting this bit specifies that valid data in MD_VALUE is ready to be written to DRAM as one of the following commands:                                                                                                                                                                     |
|        | MODE REGISTER SET     EXTENDED MODE REGISTER SET     EXTENDED MODE REGISTER SET 2     EXTENDED MODE REGISTER SET 3                                                                                                                                                                          |
|        | The specific command to be executed is selected by setting MD_SEL. In addition, the chip select must be chosen by setting CS_SEL. MD_EN is set by software and cleared by hardware once the command has been issued.                                                                        |
|        | 0 Indicates that no mode register set command needs to be issued.                                                                                                                                                                                                                           |
|        | 1 Indicates that valid data contained in the register is ready to be issued as a mode register set command.                                                                                                                                                                                 |
| 1 -    | This field is reserved. Reserved                                                                                                                                                                                                                                                            |
| 2–3    | Select chip select                                                                                                                                                                                                                                                                          |
| CS_SEL | Specifies the chip select that is driven active due to any command forced by software in DDR_SDRAM_MD_CNTL.                                                                                                                                                                                 |
|        | 00 Chip select 0 is active                                                                                                                                                                                                                                                                  |
|        | 01 Chip select 1 is active                                                                                                                                                                                                                                                                  |
|        | 10 Reserved                                                                                                                                                                                                                                                                                 |
|        | 11 Reserved                                                                                                                                                                                                                                                                                 |
| 4 -    | This field is reserved. Reserved                                                                                                                                                                                                                                                            |
| 5–7    | Mode register select                                                                                                                                                                                                                                                                        |
| MD_SEL | MD_SEL specifies one of the following:                                                                                                                                                                                                                                                      |
|        | <ul> <li>During a mode select command, selects the SDRAM mode register to be changed</li> <li>During a precharge command, selects the SDRAM logical bank to be precharged. A precharge all command ignores this field.</li> <li>During a refresh command, this field is ignored.</li> </ul> |
|        | NOTE: MD_SEL contains the value that is presented onto the memory bank address pins (MBAn) of the DDR controller.                                                                                                                                                                           |

# DDR\_DDR\_SDRAM\_MD\_CNTL field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 000 MR<br>001 EMR<br>010 EMR2<br>011 EMR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8<br>SET_REF      | Set refresh  Forces an immediate refresh to be issued to the chip select specified by  DDR_SDRAM_MD_CNTL[CS_SEL]. This bit is set by software and cleared by hardware once the command has been issued.  0 Indicates that no refresh command needs to be issued.  1 Indicates that a refresh command is ready to be issued.                                                                                                                                                                                                                                                                              |
| 9<br>SET_PRE      | Set precharge  Forces a precharge or precharge all to be issued to the chip select specified by  DDR_SDRAM_MD_CNTL[CS_SEL]. This bit is set by software and cleared by hardware once the command has been issued.  0 Indicates that no precharge all command needs to be issued.  1 Indicates that a precharge all command is ready to be issued.                                                                                                                                                                                                                                                        |
| 10–11<br>CKE_CNTL | Clock enable control  Allows software to globally clear or set all CKE signals issued to DRAM. Once software has forced the value driven on CKE, that value continues to be forced until software clears the CKE_CNTL bits. At that time, the DDR controller continues to drive the CKE signals to the same value forced by software until another event causes the CKE signals to change (such as, self refresh entry/exit, power down entry/exit).  O CKE signals are not forced by software.  CKE signals are forced to a low value by software.  CKE signals are forced to a high value by software. |
| 12–15<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16–31<br>MD_VALUE | Mode register value  This field, which specifies the value that is presented on the memory address pins of the DDR controller during a mode register set command, is significant only when this register is used to issue a mode register set command or a precharge or precharge all command.  For a mode register set command, this field contains the data to be written to the selected mode register.  For a precharge command, only bit five is significant:  0 Issue a precharge command; MD_SEL selects the logical bank to be precharged                                                        |
|                   | 1 Issue a precharge all command; all logical banks are precharged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# 8.4.13 DDR SDRAM interval configuration (DDR\_DDR\_SDRAM\_INTERVAL)

The DDR SDRAM interval configuration register sets the number of DRAM clock cycles between bank refreshes issued to the DDR SDRAMs. In addition, the number of DRAM cycles that a page is maintained after it is accessed is provided here.





#### DDR\_DDR\_SDRAM\_INTERVAL field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15       | Refresh interval                                                                                                                                                                                                                                                                                                                                                   |
| REFINT     | Represents the number of memory bus clock cycles between refresh cycles. Depending on DDR_SDRAM_CFG_2[NUM_PR], some number of rows are refreshed in each DDR SDRAM physical bank during each refresh cycle. The value for REFINT depends on the specific SDRAMs used and the interface clock frequency. Refreshes are not issued when the REFINT is set to all 0s. |
| 16–17<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                   |
| 18–31      | Precharge interval                                                                                                                                                                                                                                                                                                                                                 |
| BSTOPRE    | Sets the duration (in memory bus clocks) that a page is retained after a DDR SDRAM access. If BSTOPRE is zero, the DDR memory controller uses auto-precharge read and write commands rather than operating in page mode. This is called global auto-precharge mode.                                                                                                |

# 8.4.14 DDR SDRAM data initialization (DDR\_DDR\_DATA\_INIT)

The DDR SDRAM data initialization register provides the value that is used to initialize memory if DDR\_SDRAM\_CFG2[D\_INIT] is set.

Address: 2000h base + 128h offset = 2128h



### DDR\_DDR\_DATA\_INIT field descriptions

| Field | Description                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------|
|       | Initialization value. Represents the value that DRAM is initialized with if DDR_SDRAM_CFG2[D_INIT] is set. |

# 8.4.15 DDR SDRAM clock control (DDR\_DDR\_SDRAM\_CLK\_CNTL)

The DDR SDRAM clock control configuration register provides a 1/8-cycle clock adjustment.

Address: 2000h base + 130h offset = 2130h



### DDR\_DDR\_SDRAM\_CLK\_CNTL field descriptions

| Field      |               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0–4        | 1             | his field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| -          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 5–8        | Clock adjust  | t end of the control |  |  |  |  |  |  |
| CLK_ADJUST |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|            | 0000          | Clock is launched aligned with address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|            | 0001          | Clock is launched 1/8 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0010          | Clock is launched 1/4 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0011          | Clock is launched 3/8 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0100          | Clock is launched 1/2 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0101          | Clock is launched 5/8 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0110          | Clock is launched 3/4 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 0111          | Clock is launched 7/8 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|            | 1000          | Clock is launched 1 applied cycle after address/command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|            | 1001-1111     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 9–31       | This field is | reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| -          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |

# 8.4.16 DDR training initialization address (DDR\_DDR\_INIT\_ADDR)

The DDR SDRAM initialization address register provides the address that is used for the data strobe to data skew adjustment and automatic  $\overline{CAS}$  to preamble calibration after POR.

#### NOTE

After the skew adjustment, this address contains bad ECC data. This is not important at POR, as all of memory should be subsequently initialized if ECC is enabled (either by software or through the use of DDR\_SDRAM\_CFG\_2[D\_INIT]).

#### NOTE

If an HRESET has been issued after the DRAM is in self-refresh mode, however, memory is not initialized, so this address should be written to using a 32-byte transaction to avoid possible ECC errors if this address could later be accessed.

Address: 2000h base + 148h offset = 2148h



#### DDR\_DDR\_INIT\_ADDR field descriptions

| Field | Description                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | Initialization address. Represents the address that is used for the data strobe to data skew adjustment and automatic CAS to preamble calibration at POR. This address is written to during the initialization sequence. |

# 8.4.17 DDR training initialization extended address (DDR\_DDR\_INIT\_EXT\_ADDR)

The DDR SDRAM initialization extended address register provides the extended address that is used for the data strobe to data skew adjustment and automatic  $\overline{CAS}$  to preamble calibration after POR.

Address: 2000h base + 14Ch offset = 214Ch



### DDR\_DDR\_INIT\_EXT\_ADDR field descriptions

| Field         | Description                                                                                                                                                                                                        |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | Use initialization address                                                                                                                                                                                         |
| UIA           |                                                                                                                                                                                                                    |
|               | 0 Use the default address for training sequence as calculated by the controller. This is the first valid<br>address in the first enabled chip select.                                                              |
|               | 1 Use the initialization address programmed in DDR_INIT_ADDR and DDR_INIT_EXT_ADDR.                                                                                                                                |
| 1–27          | This field is reserved.                                                                                                                                                                                            |
| -             | Reserved                                                                                                                                                                                                           |
| 28–31         | Initialization extended address                                                                                                                                                                                    |
| INIT_EXT_ADDR | Represents the extended address that is used for the data strobe to data skew adjustment and automatic CAS to preamble calibration at POR. This extended address is written to during the initialization sequence. |

# 8.4.18 DDR SDRAM timing configuration 4 (DDR\_TIMING\_CFG\_4)

The DDR SDRAM timing configuration 4 register provides additional timing fields required to support DDR3 memories.

Address: 2000h base + 160h offset = 2160h



#### DDR\_TIMING\_CFG\_4 field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3   | Read-to-write turnaround for same chip select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| RWT   | Specifies how many cycles are added between a read to write turnaround for transactions to the same chip select. If a value of 0000 is chosen, then the DDR controller uses the value used for transactions to different chip selects, as defined in TIMING_CFG_0[RWT]. This field can be used to improve performance when operating in burst-chop mode by forcing transactions to the same chip select to use extra cycles, while transaction to different chip selects can utilize the tri-state time on the DRAM interface. Regardless of the value that is set in this field, the value defined by TIMING_CFG_0[RWT] also is met before issuing a write command. |
|       | 0000 Default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       | 0001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       | 0010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 0011 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 1000 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 1001 9 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 1010 10 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1011 11 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1100 12 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1101 13 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1110 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4–7   | Write-to-read turnaround for same chip select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| WRT   | Specifies how many cycles are added between a write to read turnaround for transactions to the same chip select. If a value of 0000 is chosen, then the DDR controller uses the value used for transactions to different chip selects, as defined in TIMING_CFG_0[WRT]. This field can be used to improve performance                                                                                                                                                                                                                                                                                                                                                |

# **DDR\_TIMING\_CFG\_4** field descriptions (continued)

| Field        | Description                                                                                                                                                                                                              |  |  |  |  |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|              | when operating in burst-chop mode by forcing transactions to the same chip select to use extra cycles,                                                                                                                   |  |  |  |  |  |  |
|              | while transaction to different chip selects can utilize the tri-state time on the DRAM interface. Regardless of the value that is set in this field, the value defined by TIMING_CFG_0[WRT] also is met before issuing a |  |  |  |  |  |  |
|              | read command.                                                                                                                                                                                                            |  |  |  |  |  |  |
|              |                                                                                                                                                                                                                          |  |  |  |  |  |  |
|              | 0000 Default                                                                                                                                                                                                             |  |  |  |  |  |  |
|              | 0001 1 clock                                                                                                                                                                                                             |  |  |  |  |  |  |
|              | 0010 2 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0011 3 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0100 4 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0101 5 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0110 6 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0111 7 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 1000 8 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 1001 9 clocks                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 1010 10 clocks                                                                                                                                                                                                           |  |  |  |  |  |  |
|              | 1011 11 clocks                                                                                                                                                                                                           |  |  |  |  |  |  |
|              | 1100 12 clocks                                                                                                                                                                                                           |  |  |  |  |  |  |
|              | 1101                                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 1110                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 0.44         |                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 8–11<br>RRT  | Read-to-read turnaround for same chip select                                                                                                                                                                             |  |  |  |  |  |  |
|              | Specifies how many cycles are added between reads to the same chip select. If a value of 0000 is choser                                                                                                                  |  |  |  |  |  |  |
|              | then 2 cycles are required between read commands to the same chip select if 4-beat bursts are used (4 cycles are required if 8-beat bursts are used). Note that DDR3 does not support 4-beat bursts. However,            |  |  |  |  |  |  |
|              | this field may be used to add extra cycles when burst-chop mode is used, and the DDR controller must                                                                                                                     |  |  |  |  |  |  |
|              | wait 4 cycles for read-to-read transactions to the same chip select.                                                                                                                                                     |  |  |  |  |  |  |
|              | 0000 BL/0 L L                                                                                                                                                                                                            |  |  |  |  |  |  |
|              | 0000 BL/2 clocks                                                                                                                                                                                                         |  |  |  |  |  |  |
|              | 0001 BL/2 + 1 clock                                                                                                                                                                                                      |  |  |  |  |  |  |
|              | 0010 BL/2 + 2 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 0011 BL/2 + 3 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 0100 BL/2 + 4 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 0101 BL/2 + 5 clocks<br>0110 BL/2 + 6 clocks                                                                                                                                                                             |  |  |  |  |  |  |
|              | 0110 BL/2 + 6 clocks<br>0111 BL/2 + 7 clocks                                                                                                                                                                             |  |  |  |  |  |  |
|              | 1000 BL/2 + 8 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 1001 BL/2 + 9 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 1010 BL/2 + 9 clocks                                                                                                                                                                                                     |  |  |  |  |  |  |
|              | 1011 BL/2 + 11 clocks                                                                                                                                                                                                    |  |  |  |  |  |  |
|              | 1100 BL/2 + 12 clocks                                                                                                                                                                                                    |  |  |  |  |  |  |
|              | 1101 BL/2 + 13 clocks                                                                                                                                                                                                    |  |  |  |  |  |  |
|              | 1110 BL/2 + 14 clocks                                                                                                                                                                                                    |  |  |  |  |  |  |
|              | 1111 BL/2 + 15 clocks                                                                                                                                                                                                    |  |  |  |  |  |  |
| 10 15        |                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 12–15<br>WWT | Write-to-write turnaround for same chip select                                                                                                                                                                           |  |  |  |  |  |  |

# DDR\_TIMING\_CFG\_4 field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Specifies how many cycles are added between writes to the same chip select. If a value of 0000 is chosen, then 2 cycles are required between write commands to the same chip select if 4-beat bursts are used (4 cycles are required if 8-beat bursts are used). Note that DDR3 does not support 4-beat bursts. However, this field may be used to add extra cycles when burst-chop mode is used, and the DDR controller must wait 4 cycles for write-to-write transactions to the same chip select. |
|                   | 0000 BL/2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | 0001 BL/2 + 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                   | 0010 BL/2 + 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 0011 BL/2 + 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 0100 BL/2 + 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 0101 BL/2 + 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 0110 BL/2 + 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 0111 BL/2 + 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 1000 BL/2 + 8 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 1001 BL/2 + 9 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | 1010 BL/2 + 10 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 1011 BL/2 + 11 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 1100 BL/2 + 12 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 1101 BL/2 + 13 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 1110 BL/2 + 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 1111 BL/2 + 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16–29             | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 30-31<br>DLL_LOCK | DDR SDRAM DLL Lock Time. This provides the number of cycles that it takes for the DRAMs DLL to lock at POR and after exiting self refresh. The controller waits the specified number of cycles before issuing any commands after exiting POR or self refresh.                                                                                                                                                                                                                                        |
|                   | 00 200 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   | 01 512 clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   | 10 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   | 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# 8.4.19 DDR SDRAM timing configuration 5 (DDR\_TIMING\_CFG\_5)

The DDR SDRAM timing configuration 5 register provides additional timing fields required to support DDR3 memories.





DDR\_TIMING\_CFG\_5 field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0–2     | his field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| -       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 3–7     | Read to ODT on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| RODT_ON | Specifies the number of cycles that passes from when a read command is placed on the DRAM bus until the assertion of the relevant ODT signal(s). The default case (00000) provides a decode of RL - 3 cycles to support legacy of past products. RL is the read latency, derived from CAS latency + additive latency. If 2T/3T timing is used, one/two extra cycle(s) is/are automatically added to the value selected in this field.  00000 RL 3 clocks 00010 0 clocks 00011 2 clocks 00011 1 clocks |  |  |  |  |  |  |

# **DDR\_TIMING\_CFG\_5** field descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 10000 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 10001 16 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 10011 18 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 11111 30 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8 -      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9–11     | Read to ODT off                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RODT_OFF | Specifies the number of cycles that the relevant ODT signal(s) remains asserted for each read transaction. The default case (000) leaves the ODT signal(s) asserted for 3 DRAM cycles.                                                                                                                                                                                                                                                    |
|          | 000 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          | 010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 011 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 100 4 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 101 5 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 110 6 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10.11    | 111 7 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 12–14    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15–19    | Write to ODT On                                                                                                                                                                                                                                                                                                                                                                                                                           |
| WODT_ON  | Specifies the number of cycles that passes from when a write command is placed on the DRAM bus until the assertion of the relevant ODT signal(s). The default case (00000) provides a decode of WL - 3 cycles to support legacy of past products. WL is the write latency, derived from Write Latency + Additive Latency. If 2T/3T timing is used, one/two extra cycle(s) is/are automatically added to the value selected in this field. |
|          | 00000 WL - 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | 00001 0 clocks                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 00010 1 clocks                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 00011 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 01111 14 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 10000 15 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 10011 18 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 11111 30 clocks                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 20       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 21–23    | Write to ODT Off                                                                                                                                                                                                                                                                                                                                                                                                                          |
| WODT_OFF | Specifies the number of cycles that the relevant ODT signal(s) remains asserted for each write transaction. The default case (000) leaves the ODT signal(s) asserted for 3 DRAM cycles.                                                                                                                                                                                                                                                   |
|          | 000 3 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 001 1 clock                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          | 010 2 clocks                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### DDR\_TIMING\_CFG\_5 field descriptions (continued)

| Field      | Description                      |
|------------|----------------------------------|
|            | 011 3 clocks                     |
|            | 100 4 clocks                     |
|            | 101 5 clocks                     |
|            | 110 6 clocks                     |
|            | 111 7 clocks                     |
| 24–31<br>- | This field is reserved. Reserved |

## 8.4.20 DDR ZQ calibration control (DDR\_DDR\_ZQ\_CNTL)

The DDR ZQ calibration control register provides the enable and controls required for ZQ calibration when using DDR3 SDRAM devices.

There is a limitation for various DRAM timing parameters when ZQ calibration is used. The following factors are involved in this limitation:

- DDR\_ZQ\_CNTL[ZQOPER]
- DDR\_ZQ\_CNTL[ZQCS]
- TIMING\_CFG\_1[PRETOACT]
- TIMING\_CFG\_1[REFREC]
- DDR SDRAM INTERVAL[REFINT]
- the number of chip selects enabled

If the following condition is true:

[((DDR\_ZQ\_CNTL[ZQOPER] + DDR\_ZQ\_CNTL[ZQCS]) x (# enabled chip selects)) + TIMING\_CFG\_1[PRETOACT] +

 $TIMING\_CFG\_1[REFREC] + 2t_{CK}] > (DDR\_SDRAM\_INTERVAL[REFINT]),$ 

Then it is possible that one refresh is skipped when the controller is exiting self refresh. If this is an issue, then posted refreshes could be used to extend the refresh interval. Another alternative is to use the DDR\_SDRAM\_MD\_CNTL register to force an extra refresh to each chip select after exiting self refresh mode. However, DDR3 timing parameters for most devices/frequencies do not allow for a refresh to be missed.

Address: 2000h base + 170h offset = 2170h



#### DDR memory map/register definition

| Bit    | 16       | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27   | 28    | 29 | 30 | 31 |
|--------|----------|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|
| R<br>W | Reserved |    |    |    |    | ZQ | cs |    |    |    |    | Rese | erved |    |    |    |
| Reset  | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0  | 0  | 0  |

# DDR\_DDR\_ZQ\_CNTL field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ZQ_EN      | ZQ Calibration Enable. This bit determines if ZQ calibration is used. This bit should only be set if DDR3 memory is used (DDR_SDRAM_CFG[SDRAM_TYPE] = 3'b111).                                                                                                                                                                                                                     |
|                 | 0 ZQ Calibration is not used.                                                                                                                                                                                                                                                                                                                                                      |
|                 | 1 ZQ Calibration is used. A ZQCL command is issued by the DDR controller after POR and anytime the DDR controller is exiting self refresh. A ZQCS command is issued every 32 refresh sequences to account for VT variations.                                                                                                                                                       |
| 1–3<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                   |
| 4–7<br>ZQINIT   | POR ZQ Calibration Time (t <sub>ZQinit</sub> ). Determines the number of cycles that must be allowed for DRAM ZQ calibration at POR. Each chip select is calibrated separately, and this time must elapse after the ZQCL command is issued for each chip select before a separate command may be issued.                                                                           |
|                 | 0000-0110 Reserved                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 0111 128 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1000 256 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1001 512 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1010 1024 clocks                                                                                                                                                                                                                                                                                                                                                                   |
|                 | 1011-1111 Reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 8–11<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                   |
| 12–15<br>ZQOPER | Normal Operation Full Calibration Time ( $t_{ZQoper}$ ). Determines the number of cycles that must be allowed for DRAM ZQ calibration when exiting self refresh. Each chip select is calibrated separately, and this time must elapse after the ZQCL command is issued for each chip select before a separate command may be issued.                                               |
|                 | 0000-0110 Reserved                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 0111 128 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1000 256 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1001 512 clocks                                                                                                                                                                                                                                                                                                                                                                    |
|                 | 1010 1024 clocks                                                                                                                                                                                                                                                                                                                                                                   |
|                 | 1011-1111 Reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 16–19<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                   |
| 20–23<br>ZQCS   | Normal Operation Short Calibration Time (t <sub>ZQCS</sub> ). Determines the number of cycles that must be allowed for DRAM ZQ calibration during dynamic calibration which is issued every 32 refresh cycles. Each chip select is calibrated separately, and this time must elapse after the ZQCS command is issued for each chip select before a separate command may be issued. |
|                 | 0000 1 clocks                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 1 010010                                                                                                                                                                                                                                                                                                                                                                           |
|                 | 0001 2 clocks                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 0001 2 clocks<br>0010 4 clocks                                                                                                                                                                                                                                                                                                                                                     |
|                 | 0001 2 clocks<br>0010 4 clocks<br>0011 8 clocks                                                                                                                                                                                                                                                                                                                                    |

### DDR\_DDR\_ZQ\_CNTL field descriptions (continued)

| Field      | Description               |            |  |  |  |  |
|------------|---------------------------|------------|--|--|--|--|
|            | 0101                      | 32 clocks  |  |  |  |  |
|            | 0110                      | 64 clocks  |  |  |  |  |
|            | 0111                      | 128 clocks |  |  |  |  |
|            | 1000                      | 256 clocks |  |  |  |  |
|            | 1001                      | 512 clocks |  |  |  |  |
|            | 1010-1111                 | Reserved   |  |  |  |  |
| 24–31<br>- | This field is<br>Reserved | reserved.  |  |  |  |  |

# 8.4.21 DDR write leveling control (DDR\_DDR\_WRLVL\_CNTL)

The DDR write leveling control register provides controls for write leveling, as it is supported for DDR3 memory devices.

Address: 2000h base + 174h offset = 2174h



DDR\_DDR\_WRLVL\_CNTL field descriptions

| Field    | Description             |  |  |  |  |
|----------|-------------------------|--|--|--|--|
| 0        | 0 Write Leveling Enable |  |  |  |  |
| WRLVL EN |                         |  |  |  |  |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# DDR\_DDR\_WRLVL\_CNTL field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                               |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | This bit determines if write leveling is used. If this bit is set, then the DDR controller performs write leveling immediately after initializing the DRAM. This bit should only be set if DDR3 memory is used (DDR_SDRAM_CFG[SDRAM_TYPE] = 3'b111).                                      |
|                      | Write leveling is not used     Write leveling is used                                                                                                                                                                                                                                     |
| 1–4                  | This field is reserved. Reserved                                                                                                                                                                                                                                                          |
| 5–7<br>WRLVL_MRD     | First DQS pulse rising edge after margining mode is programmed (t <sub>WL_MRD</sub> ). Determines how many cycles to wait after margining mode has been programmed before the first DQS pulse may be issued. This field is only relevant when DDR_WRLVL_CNTL[WRLVL_EN] is set.            |
|                      | 000 1 clocks<br>001 2 clocks                                                                                                                                                                                                                                                              |
|                      | 010 4 clocks 011 8 clocks                                                                                                                                                                                                                                                                 |
|                      | 100 16 clocks 101 32 clocks                                                                                                                                                                                                                                                               |
|                      | 110 64 clocks<br>111 128 clocks                                                                                                                                                                                                                                                           |
| 8 -                  | This field is reserved. Reserved                                                                                                                                                                                                                                                          |
| 9–11<br>WRLVL_ODTEN  | ODT delay after margining mode is programmed (t <sub>WL_ODTEN</sub> ). Determines how many cycles to wait after margining mode has been programmed until ODT may be asserted. This field is only relevant when DDR_WRLVL_CNTL[WRLVL_EN] is set.                                           |
|                      | 000 1 clocks                                                                                                                                                                                                                                                                              |
|                      | 001 2 clocks                                                                                                                                                                                                                                                                              |
|                      | 010 4 clocks                                                                                                                                                                                                                                                                              |
|                      | 011 8 clocks                                                                                                                                                                                                                                                                              |
|                      | 100 16 clocks                                                                                                                                                                                                                                                                             |
|                      | 101 32 clocks                                                                                                                                                                                                                                                                             |
|                      | 110 64 clocks<br>111 128 clocks                                                                                                                                                                                                                                                           |
| 12<br>-              | This field is reserved. Reserved                                                                                                                                                                                                                                                          |
| 13–15<br>WRLVL_DQSEN | DQS/ $\overline{\text{DQS}}$ delay after margining mode is programmed (t $_{\text{WL}_{\text{DQSEN}}}$ ). Determines how many cycles to wait after margining mode has been programmed until DQS may be actively driven. This field is only relevant when DDR_WRLVL_CNTL[WRLVL_EN] is set. |
|                      | 000 1 clocks                                                                                                                                                                                                                                                                              |
|                      | 001 2 clocks                                                                                                                                                                                                                                                                              |
|                      | 010 4 clocks                                                                                                                                                                                                                                                                              |
|                      | 011 8 clocks                                                                                                                                                                                                                                                                              |
|                      | 100 16 clocks                                                                                                                                                                                                                                                                             |
|                      | 101 32 clocks                                                                                                                                                                                                                                                                             |
|                      | 110 64 clocks                                                                                                                                                                                                                                                                             |
|                      | 111 128 clocks                                                                                                                                                                                                                                                                            |

# DDR\_DDR\_WRLVL\_CNTL field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 16–19                | Write leveling sample time                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| WRLVL_SMPL           | Determines the number of cycles that must pass before the data signals are sampled after a DQS pulse during margining mode. This field should be programmed at least 6 cycles higher than t <sub>WLO</sub> to allow enough time for propagation delay and sampling of the prime data bits. This field is only relevant when DDR_WRLVL_CNTL[WRLVL_EN] is set. |  |  |  |  |  |  |
|                      | 0000 Reserved (if DDR_WRLVL_CNTL[WRLVL_EN] is set)                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                      | 0001 1 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0010 2 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0011 3 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0100 4 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0101 5 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0110 6 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 0111 7 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 1000 8 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 1001 9 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 1010 10 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 1011 11 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 1100 12 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 1101 13 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 1110 14 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 1111 15 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 20                   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| 21–23                | Write leveling repetition time                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| WRLVL_WLR            | Determines the number of cycles that must pass between DQS pulses during write leveling. This field is only relevant when DDR_WRLVL_CNTL[WRLVL_EN] is set.                                                                                                                                                                                                   |  |  |  |  |  |  |
|                      | 000 1 clocks                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|                      | 001 2 clocks                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|                      | 010 4 clocks                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|                      | 011 8 clocks                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|                      | 100 16 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 101 32 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 110 64 clocks                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                      | 111 128 clocks                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 24–27                | This field is reserved.                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| -                    | Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 28–31<br>WRLVL_START | Write leveling start time. Determines the value to use for the DQS_ADJUST for the first sample when write leveling is enabled.                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                      | 0000 0 clock delay                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                      | 0001 1/8 clock delay                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|                      | 0010 1/4 clock delay                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|                      | 0010 1/4 clock delay                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|                      |                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|                      |                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|                      | 0101 5/8 clock delay                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|                      | 0110 3/4 clock delay                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |

### DDR\_DDR\_WRLVL\_CNTL field descriptions (continued)

| Field |      | Description      |
|-------|------|------------------|
|       | 0111 | 7/8 clock delay  |
|       | 1000 | 1 clock delay    |
|       | 1001 | 9/8 clock delay  |
|       | 1010 | 5/4 clock delay  |
|       | 1011 | 11/8 clock delay |
|       | 1100 | 3/2 clock delay  |
|       | 1101 | 13/8 clock delay |
|       | 1110 | 7/4 clock delay  |
|       | 1111 | 15/8 clock delay |

### 8.4.22 DDR Self Refresh Counter (DDR\_DDR\_SR\_CNTR)

The DDR self-refresh counter register can be programmed to force the DDR controller to enter self-refresh after a predefined period of idle time.

Address: 2000h base + 17Ch offset = 217Ch



#### DDR\_DDR\_SR\_CNTR field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0–11<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| 12–15     | Self Refresh Idle Threshold                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
| SR_IT     | Defines the number of DRAM cycles that must pass while the DDR controller is idle before it will enter self refresh. Anytime a transaction is issued to the DDR controller, it will reset its internal counter. When a new transaction is received by the DDR controller, it will exit self refresh and reset its internal counter. If this field is zero, then the described power savings feature is disabled. In addition, if a non-zero value is programmed into this field, then the DDR controller will exit self refresh anytime a transaction is issued to the DDR controller, regardless of the reason self refresh was initially entered. |  |  |  |  |  |  |  |  |  |
|           | If this field is set to a non-zero value, then DDR_SDRAM_CFG[SREN] must also be set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|           | Patterns not shown are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|           | NOTE: The term 'clock' refers to the data rate rather than the clock frequency of the DDR interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|           | 0000 Automatic self refresh entry disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
|           | 0001 2^10 DRAM clocks (DDR2 only; reserved for DDR3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|           | 0010 2^12 DRAM clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|           | 0011 2^14 DRAM clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|           | 0100 2^16 DRAM clocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |

#### DDR\_DDR\_SR\_CNTR field descriptions (continued)

| Field      | Description                      |
|------------|----------------------------------|
|            | 0101 2^18 DRAM clocks            |
|            | 0110 2^20 DRAM clocks            |
|            | 0111 2^22 DRAM clocks            |
|            | 1000 2^24 DRAM clocks            |
|            | 1001 2^26 DRAM clocks            |
|            | 1010 2^28 DRAM clocks            |
|            | 1011 2^30 DRAM clocks            |
| 16–31<br>- | This field is reserved. Reserved |

# 8.4.23 DDR Register Control Words 1 (DDR\_DDR\_SDRAM\_RCW\_1)

The DDR register control word 1 register should be programmed with the intended values of the register control words if DDR\_SDRAM\_CFG[RCW\_EN] is set. Each 4-bit field represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during register control word writes.

Address: 2000h base + 180h offset = 2180h



#### DDR\_DDR\_SDRAM\_RCW\_1 field descriptions

| Field         | Description                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3<br>RCW0   | Register Control Word 0. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 0. |
| 4–7<br>RCW1   | Register Control Word 1. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 1. |
| 8–11<br>RCW2  | Register Control Word 2. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 2. |
| 12–15<br>RCW3 | Register Control Word 3. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 3. |
| 16–19<br>RCW4 | Register Control Word 4. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 4. |
| 20–23<br>RCW5 | Register Control Word 5. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 5. |
| 24–27<br>RCW6 | Register Control Word 6. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 6. |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### DDR\_DDR\_SDRAM\_RCW\_1 field descriptions (continued)

| Field | Description                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
|       | Register Control Word 7. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 7. |

# 8.4.24 DDR Register Control Words 2 (DDR\_DDR\_SDRAM\_RCW\_2)

The DDR register control word 2 register should be programmed with the intended values of the register control words if DDR\_SDRAM\_CFG[RCW\_EN] is set. Each 4-bit field represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during register control word writes.

Address: 2000h base + 184h offset = 2184h

| Bit    | 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 |  |     |     |  |  |     |     |  |  |     |     |  |  |     |     |  |  |     |     |  |
|--------|----------|---|------|---|------|---|------|------|---|------|----|------|------|----|------|------|------|------|------|-----|-----|-----|-----|-----|----|----|----|----|----|----|-----|----|--|-----|-----|--|--|-----|-----|--|--|-----|-----|--|--|-----|-----|--|--|-----|-----|--|
| R<br>W | R<br>W F |   | RCW8 |   | RCW8 |   | RCW8 | RCW8 |   | RCW8 |    | RCW8 | RCW8 |    | RCW8 | RCW8 | RCW8 | RCW8 | RCW8 | CW8 | CW8 | CW8 | CW8 | 8W3 |    | RC | W9 |    |    | RC | W10 |    |  | RCV | W11 |  |  | RCV | W12 |  |  | RC\ | N13 |  |  | RCV | W14 |  |  | RCV | V15 |  |
| Reset  | 0        | 0 | 0    | 0 | 0    | 0 | 0    | 0    | 0 | 0    | 0  | 0    | 0    | 0  | 0    | 0    | 0    | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |  |     |     |  |  |     |     |  |  |     |     |  |  |     |     |  |  |     |     |  |

### DDR\_DDR\_SDRAM\_RCW\_2 field descriptions

| Field          | Description                                                                                                                                  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3<br>RCW8    | Register Control Word 8. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 8.   |
| 4–7<br>RCW9    | Register Control Word 9. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 9.   |
| 8–11<br>RCW10  | Register Control Word 10. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 10. |
| 12–15<br>RCW11 | Register Control Word 11. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 11. |
| 16–19<br>RCW12 | Register Control Word 12. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 12. |
| 20–23<br>RCW13 | Register Control Word 13. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 13. |
| 24–27<br>RCW14 | Register Control Word 14. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 14. |
| 28–31<br>RCW15 | Register Control Word 15. Represents the value that is placed on MBA[1], MBA[0], MA[4], and MA[3] during writes to register control word 15. |

# 8.4.25 DDR write leveling control 2 (DDR\_DDR\_WRLVL\_CNTL\_2)

The DDR write leveling control 2 register provides controls for write leveling, as it is supported for DDR3 memory devices. This register specifically defines the starting points for the individual data strobes.





#### DDR\_DDR\_WRLVL\_CNTL\_2 field descriptions

| Field               | Description                                                                                                                               |                  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|--|--|--|--|--|--|--|--|--|
| 0–2                 | This field is reserved.                                                                                                                   |                  |  |  |  |  |  |  |  |  |  |  |  |
| -                   | Reserved                                                                                                                                  |                  |  |  |  |  |  |  |  |  |  |  |  |
| 3–7<br>WRLVL_START_ | Write leveling start time for DQS[1]. Determines the value to use for the DQS_ADJUST for the first sample when write leveling is enabled. |                  |  |  |  |  |  |  |  |  |  |  |  |
| 1                   | 00000 Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                                          |                  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00001                                                                                                                                     | 1/8 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00010                                                                                                                                     | 1/4 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00011                                                                                                                                     | 3/8 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00100                                                                                                                                     | 1/2 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00101                                                                                                                                     | 5/8 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00110                                                                                                                                     | 3/4 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 00111                                                                                                                                     | 7/8 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01000                                                                                                                                     | 1 clock delay    |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01001                                                                                                                                     | 9/8 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01010                                                                                                                                     | 5/4 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01011                                                                                                                                     | 11/8 clock delay |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01100                                                                                                                                     | 3/2 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01101                                                                                                                                     | 13/8 clock delay |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01110                                                                                                                                     | 7/4 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 01111                                                                                                                                     | 15/8 clock delay |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10000                                                                                                                                     | 2 clock delay    |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10001                                                                                                                                     | 17/8 clock delay |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10010                                                                                                                                     | 9/4 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10011                                                                                                                                     | 19/8 clock delay |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10100                                                                                                                                     | 5/2 clock delay  |  |  |  |  |  |  |  |  |  |  |  |
|                     | 10101-11111                                                                                                                               | Reserved         |  |  |  |  |  |  |  |  |  |  |  |
| 8–10<br>-           | This field is res<br>Reserved                                                                                                             | served.          |  |  |  |  |  |  |  |  |  |  |  |

# DDR\_DDR\_WRLVL\_CNTL\_2 field descriptions (continued)

| Field                      |                                                                                                                                           | Description                                |  |  |  |  |  |  |  |  |  |  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 11–15<br>WRLVL_START_<br>2 | Write leveling start time for DQS[2]. Determines the value to use for the DQS_ADJUST for the first sample when write leveling is enabled. |                                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00000                                                                                                                                     | Use value from DDR_WRLVL_CNTL[WRLVL_START] |  |  |  |  |  |  |  |  |  |  |
|                            | 00001                                                                                                                                     | 1/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00010                                                                                                                                     | 1/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00011                                                                                                                                     | 3/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00100                                                                                                                                     | 1/2 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00101                                                                                                                                     | 5/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00110                                                                                                                                     | 3/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00111                                                                                                                                     | 7/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01000                                                                                                                                     | 1 clock delay                              |  |  |  |  |  |  |  |  |  |  |
|                            | 01001                                                                                                                                     | 9/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01010                                                                                                                                     | 5/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01011                                                                                                                                     | 11/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 01100                                                                                                                                     | 3/2 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01101                                                                                                                                     | 13/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 01110                                                                                                                                     | 7/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01111                                                                                                                                     | 15/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 10000                                                                                                                                     | 2 clock delay                              |  |  |  |  |  |  |  |  |  |  |
|                            | 10001                                                                                                                                     | 17/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 10010                                                                                                                                     | 9/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 10011                                                                                                                                     | 19/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 10100                                                                                                                                     | 5/2 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 10101-11111                                                                                                                               | Reserved                                   |  |  |  |  |  |  |  |  |  |  |
| 16–18<br>-                 | This field is res<br>Reserved                                                                                                             | served.                                    |  |  |  |  |  |  |  |  |  |  |
| 19–23<br>WRLVL_START_<br>3 | Write leveling start time for DQS[3]. Determines the value to use for the DQS_ADJUST for the first sample when write leveling is enabled. |                                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00000                                                                                                                                     | Use value from DDR_WRLVL_CNTL[WRLVL_START] |  |  |  |  |  |  |  |  |  |  |
|                            | 00001                                                                                                                                     | 1/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00010                                                                                                                                     | 1/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00011                                                                                                                                     | 3/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00100                                                                                                                                     | 1/2 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00101                                                                                                                                     | 5/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00110                                                                                                                                     | 3/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 00111                                                                                                                                     | 7/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01000                                                                                                                                     | 1 clock delay                              |  |  |  |  |  |  |  |  |  |  |
|                            | 01001                                                                                                                                     | 9/8 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01010                                                                                                                                     | 5/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01011                                                                                                                                     | 11/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 01100                                                                                                                                     | 3/2 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01101                                                                                                                                     | 13/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 01110                                                                                                                                     | 7/4 clock delay                            |  |  |  |  |  |  |  |  |  |  |
|                            | 01111                                                                                                                                     | 15/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |
|                            | 10000                                                                                                                                     | 2 clock delay                              |  |  |  |  |  |  |  |  |  |  |
|                            | 10001                                                                                                                                     | 17/8 clock delay                           |  |  |  |  |  |  |  |  |  |  |

## DDR\_DDR\_WRLVL\_CNTL\_2 field descriptions (continued)

| Field                      |                               | Description                                                                                                  |  |  |  |  |  |  |
|----------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                            | 10010                         | 9/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 10011                         | 19/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 10100                         | 5/2 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 10101-11111                   | Reserved                                                                                                     |  |  |  |  |  |  |
| 24–26<br>-                 | This field is res<br>Reserved | reserved.                                                                                                    |  |  |  |  |  |  |
| 27–31<br>WRLVL_START_<br>4 |                               | start time for DQS[4]. Determines the value to use for the DQS_ADJUST for the first sample eling is enabled. |  |  |  |  |  |  |
| 4                          | 00000                         | Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                   |  |  |  |  |  |  |
|                            | 00001                         | 1/8 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00010                         | 1/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00011                         | 3/8 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00100                         | 1/2 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00101                         | 5/8 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00110                         | 3/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 00111                         | 7/8 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 01000                         | 1 clock delay                                                                                                |  |  |  |  |  |  |
|                            | 01001                         | 9/8 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 01010                         | 5/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 01011                         | 11/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 01100                         | 3/2 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 01101                         | 13/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 01110                         | 7/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 01111                         | 15/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 10000                         | 2 clock delay                                                                                                |  |  |  |  |  |  |
|                            | 10001                         | 17/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 10010                         | 9/4 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 10011                         | 19/8 clock delay                                                                                             |  |  |  |  |  |  |
|                            | 10100                         | 5/2 clock delay                                                                                              |  |  |  |  |  |  |
|                            | 10101-11111                   | Reserved                                                                                                     |  |  |  |  |  |  |

## 8.4.26 DDR write leveling control 3 (DDR\_DDR\_WRLVL\_CNTL\_3)

The DDR write leveling control 3 register provides controls for write leveling, as it is supported for DDR3 memory devices. This register specifically defines the starting points for the individual data strobes.

Address: 2000h base + 194h offset = 2194h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## DDR\_DDR\_WRLVL\_CNTL\_3 field descriptions

| Field                    | Description                      |                                                                                                              |  |  |  |  |  |
|--------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0–2<br>-                 | This field is reserved. Reserved |                                                                                                              |  |  |  |  |  |
| 3–7<br>WRLVL_START_<br>5 |                                  | start time for DQS[5]. Determines the value to use for the DQS_ADJUST for the first sample eling is enabled. |  |  |  |  |  |
|                          | 00000                            | Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                   |  |  |  |  |  |
|                          | 00001                            | 1/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00010                            | 1/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 00011                            | 3/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00100                            | 1/2 clock delay                                                                                              |  |  |  |  |  |
|                          | 00101                            | 5/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00110                            | 3/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 00111                            | 7/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 01000                            | 1 clock delay                                                                                                |  |  |  |  |  |
|                          | 01001                            | 9/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 01010                            | 5/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 01011                            | 11/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 01100                            | 3/2 clock delay                                                                                              |  |  |  |  |  |
|                          | 01101                            | 13/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 01110                            | 7/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 01111                            | 15/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 10000                            | 2 clock delay                                                                                                |  |  |  |  |  |
|                          | 10001                            | 17/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 10010                            | 9/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 10011                            | 19/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 10100                            | 5/2 clock delay                                                                                              |  |  |  |  |  |
|                          | 10101-11111                      | Reserved                                                                                                     |  |  |  |  |  |
| 8–10<br>-                | This field is res<br>Reserved    | served.                                                                                                      |  |  |  |  |  |
| 11–15<br>WRLVL_START_    |                                  | start time for DQS[6]. Determines the value to use for the DQS_ADJUST for the first sample eling is enabled. |  |  |  |  |  |
| 6                        | 00000                            | Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                   |  |  |  |  |  |
|                          | 00001                            | 1/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00010                            | 1/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 00011                            | 3/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00100                            | 1/2 clock delay                                                                                              |  |  |  |  |  |
|                          | 00101                            | 5/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 00110                            | 3/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 00111                            | 7/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 01000                            | 1 clock delay                                                                                                |  |  |  |  |  |
|                          | 01001                            | 9/8 clock delay                                                                                              |  |  |  |  |  |
|                          | 01010                            | 5/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 01011                            | 11/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 01100                            | 3/2 clock delay                                                                                              |  |  |  |  |  |
|                          | 01101                            | 13/8 clock delay                                                                                             |  |  |  |  |  |
|                          | 01110                            | 7/4 clock delay                                                                                              |  |  |  |  |  |
|                          | 01111                            | 15/8 clock delay                                                                                             |  |  |  |  |  |

## DDR\_DDR\_WRLVL\_CNTL\_3 field descriptions (continued)

| Field                      |                               | Description                                                                                                  |
|----------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------|
|                            | 10000                         | 2 clock delay                                                                                                |
|                            | 10001                         | 17/8 clock delay                                                                                             |
|                            | 10010                         | 9/4 clock delay                                                                                              |
|                            | 10011                         | 19/8 clock delay                                                                                             |
|                            | 10100                         | 5/2 clock delay                                                                                              |
|                            | 10101-11111                   | Reserved                                                                                                     |
| 16–18                      | This field is res<br>Reserved | erved.                                                                                                       |
| -                          |                               |                                                                                                              |
| 19–23<br>WRLVL_START_<br>7 |                               | start time for DQS[7]. Determines the value to use for the DQS_ADJUST for the first sample eling is enabled. |
| ,                          | 00000                         | Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                   |
|                            | 00001                         | 1/8 clock delay                                                                                              |
|                            | 00010                         | 1/4 clock delay                                                                                              |
|                            | 00011                         | 3/8 clock delay                                                                                              |
|                            | 00100                         | 1/2 clock delay                                                                                              |
|                            | 00101                         | 5/8 clock delay                                                                                              |
|                            | 00110                         | 3/4 clock delay                                                                                              |
|                            | 00111                         | 7/8 clock delay                                                                                              |
|                            | 01000                         | 1 clock delay                                                                                                |
|                            | 01001                         | 9/8 clock delay                                                                                              |
|                            | 01010                         | 5/4 clock delay                                                                                              |
|                            | 01011                         | 11/8 clock delay                                                                                             |
|                            | 01100                         | 3/2 clock delay                                                                                              |
|                            | 01101                         | 13/8 clock delay                                                                                             |
|                            | 01110                         | 7/4 clock delay                                                                                              |
|                            | 01111                         | 15/8 clock delay                                                                                             |
|                            | 10000                         | 2 clock delay                                                                                                |
|                            | 10001                         | 17/8 clock delay                                                                                             |
|                            | 10010                         | 9/4 clock delay                                                                                              |
|                            | 10011                         | 19/8 clock delay                                                                                             |
|                            | 10100                         | 5/2 clock delay                                                                                              |
|                            | 10101-11111                   | Reserved                                                                                                     |
| 24–26<br>-                 | This field is res<br>Reserved | served.                                                                                                      |
| 27–31<br>WRLVL_START_      |                               | start time for DQS[8]. Determines the value to use for the DQS_ADJUST for the first sample eling is enabled. |
| 8                          | 00000                         | Use value from DDR_WRLVL_CNTL[WRLVL_START]                                                                   |
|                            | 00001                         | 1/8 clock delay                                                                                              |
|                            | 00010                         | 1/4 clock delay                                                                                              |
|                            | 00011                         | 3/8 clock delay                                                                                              |
|                            | 00100                         | 1/2 clock delay                                                                                              |
|                            | 00101                         | 5/8 clock delay                                                                                              |
|                            | 00110                         | 3/4 clock delay                                                                                              |
|                            | 00111                         | 7/8 clock delay                                                                                              |
|                            | 01000                         | 1 clock delay                                                                                                |
| l .                        | 1                             | •                                                                                                            |

## DDR\_DDR\_WRLVL\_CNTL\_3 field descriptions (continued)

| Field |             | Description      |
|-------|-------------|------------------|
|       | 01001       | 9/8 clock delay  |
|       | 01010       | 5/4 clock delay  |
|       | 01011       | 11/8 clock delay |
|       | 01100       | 3/2 clock delay  |
|       | 01101       | 13/8 clock delay |
|       | 01110       | 7/4 clock delay  |
|       | 01111       | 15/8 clock delay |
|       | 10000       | 2 clock delay    |
|       | 10001       | 17/8 clock delay |
|       | 10010       | 9/4 clock delay  |
|       | 10011       | 19/8 clock delay |
|       | 10100       | 5/2 clock delay  |
|       | 10101-11111 | Reserved         |

# 8.4.27 DDR Debug Status Register 1 (DDR\_DDRDSR\_1)

The DDRDSR\_1 register contains the DDR driver compensation input value and the current settings of the P and N FET impedance for MDICn, command/control, and data.





#### DDR\_DDRDSR\_1 field descriptions

| Field         | Description                                          |
|---------------|------------------------------------------------------|
| 0-1<br>DDRDC  | DDR driver compensation input value                  |
| 2-5<br>MDICPZ | Current setting of PFET driver MDIC impedance        |
| 6-9<br>MDICNZ | Current setting of NFET driver MDIC impedance        |
| 10–15<br>-    | This field is reserved. Reserved, should be cleared. |

### DDR\_DDRDSR\_1 field descriptions (continued)

| Field        | Description                                      |
|--------------|--------------------------------------------------|
| 16–19<br>CPZ | Current setting of PFET driver command impedance |
| 20–23<br>CNZ | Current setting of NFET driver command impedance |
| 24–27<br>DPZ | Current setting of PFET driver data impedance    |
| 28–31<br>DNZ | Current setting of NFET driver data impedance    |

## 8.4.28 DDR Debug Status Register 2 (DDR\_DDRDSR\_2)

The DDRDSR\_2 register contains the current settings of the P and N FET impedance for the DDR drivers for clocks.

Address: 2000h base + B24h offset = 2B24h



### DDR\_DDRDSR\_2 field descriptions

| Field        | Description                                    |
|--------------|------------------------------------------------|
| 0–3<br>CLKPZ | Current setting of PFET driver clock impedance |
| 4–7<br>CLKNZ | Current setting of NFET driver clock impedance |
| 8–31<br>-    | This field is reserved. Reserved               |

## 8.4.29 DDR Control Driver Register 1 (DDR\_DDRCDR\_1)

DDRCDR\_1 sets the driver hardware compensation enable, the DDR MDIC driver P/N impedance, ODT termination value for IOs, driver software override enable for MDIC, driver software override enable for address/command, driver software override enable for data, the DDR address/command driver P/N impedance, and the DDR data driver P/N impedance.

#### DDR memory map/register definition

The fields in DDRCDR\_1, other than DDRCDR\_1[ODT], are used to enable driver calibration with the MDIC[0:1] pins. This can be used to calibrate the DDR drivers to the external calibration resistors on the MDIC pins. However, this should only be used for full-strength driver applications.

Hardware DDR driver calibration is enabled by setting DDRCDR\_1[DHC\_EN].

#### NOTE

All driver calibration, whether by software or hardware, should be done before the DDR controller is enabled (before DDR\_SDRAM\_CFG[MEM\_EN] is set).

Software can be used to calibrate the drivers instead of the automatic hardware calibration. If software calibration is used, the following steps should be taken:

- 1. Set DDRCDR\_1[DSO\_MDIC\_EN] and ensure that DDRCDR\_1[DHC\_EN] is cleared
- 2. Set the highest impedance (value 0000) for DDRCDR\_1[DSO\_MDICPZ]
- 3. Set DDRCDR\_1[DSO\_MDIC\_PZ\_OE] to enable the output enable for MDIC[0]
- 4. After at least 4 cycles, read DDRDSR\_1[0]. If the value is 0, then use the next lowest impedance, and read DDRDSR\_1[0] again. Once a value of 1 is detected, then leave DDRCDR\_1[DSO\_MDICPZ] at the calibrated value
- 5. Clear DDRCDR\_1[DSO\_MDIC\_PZ\_OE]
- 6. After DDRCDR\_1[DSO\_MDICPZ] is calibrated, set a value of 0000 for DDRCDR\_1[DSO\_MDICNZ]
- 7. Set DDRCDR\_1[DSO\_MDIC\_NZ\_OE] to enable the output enable for MDIC[1]
- 8. After at least 4 cycles, read DDRDSR\_1[1]. If the value is 1, then use the next lowest impedance, and read DDRDSR\_1[1] again. Once a value of 0 is detected, then leave DDRCDR\_1[DSO\_MDICNZ] at the calibrated value
- 9. Clear DDRCDR\_1[DSO\_MDIC\_NZ\_OE]

The table below lists the valid impedance override values from highest impedance (lowest drive strength) to lowest impedance (highest drive strength). Note that the drivers may be calibrated to either full-strength or half-strength.

**Table 8-41. Valid Impedance Override Values** 

| Driver Impedance | Impedance Override Values | Notes |
|------------------|---------------------------|-------|
| Highest          | 0000                      | -     |
|                  | 0001                      | -     |
|                  | 0011                      | -     |
|                  | 0010                      | -     |
|                  | 0110                      | -     |
|                  | 0111                      | 1     |
|                  | 0101                      | -     |
|                  | 0100                      | -     |
|                  | 1100                      | -     |
|                  | 1101                      | -     |
|                  | 1111                      | -     |
|                  | 1110                      | -     |
|                  | 1010                      | -     |
|                  | 1011                      | 2     |
|                  | 1001                      | -     |
| Lowest           | 1000                      | 3     |

- 1. 0111 provides the target for half-strength mode in both DDR2 (1.8 V) and DDR3 (1.5 V) modes when driver calibration is not used.
- 2. 1011 provides the target for full-strength mode in DDR2 (1.8 V) when driver calibration is not used.
- 3. 1000 provides the target for full-strength mode in DDR3 mode (1.5 V) when driver calibration is not used.

Address: 2000h base + B28h offset = 2B28h

| Bit   | 0      | 1            | 2    | 3     | 4      | 5            | 6     | 7     | 8      | 9   | 10               | 11               | 12 | 13           | 14       | 15       |
|-------|--------|--------------|------|-------|--------|--------------|-------|-------|--------|-----|------------------|------------------|----|--------------|----------|----------|
| R     | DHC_EN | DSO_MDIC_EN  |      | DSO_M | 1DICPZ |              |       | DSO_N | IDICNZ |     | O_MDIC_PZ_<br>OE | O_MDIC_NZ_<br>OE | OI | DΤ           | DSO_C_EN | DSO_D_EN |
|       |        | 8            |      |       |        |              |       |       |        |     | DSO              | DSO              |    |              | _        | _        |
| Reset | 0      | 0            | 0    | 0     | 0      | 0            | 0     | 0     | 0      | 0   | 0                | 0                | 0  | 0            | 0        | 0        |
| Bit   | 16     | 17           | 18   | 19    | 20     | 21           | 22    | 23    | 24     | 25  | 26               | 27               | 28 | 29           | 30       | 31       |
| R     |        |              |      |       |        |              |       |       |        |     |                  |                  |    |              |          |          |
|       |        | DSO          | _CPZ |       |        | DSO          | _CNZ  |       |        | DSO | _DPZ             |                  |    | DSO          | _DNZ     |          |
| ,,,   |        | D30 <u>.</u> | _01  |       |        | D30 <u>.</u> | _OIVZ |       |        | D30 | _DI Z            |                  |    | D30 <u>.</u> | _DINZ    |          |
| W     |        |              |      |       |        |              |       |       |        |     |                  |                  |    |              |          |          |
| Reset | 0      | 0            | 0    | 0     | 0      | 0            | 0     | 0     | 0      | 0   | 0                | 0                | 0  | 0            | 0        | 0        |

#### DDR memory map/register definition

## DDR\_DDRCDR\_1 field descriptions

| Field                    | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>DHC_EN              | DDR driver hardware compensation enable                                                                                                                                                                                                                                                                                                       |
| 1<br>DSO_MDIC_EN         | Driver software override enable for MDIC                                                                                                                                                                                                                                                                                                      |
| 2–5<br>DSO_MDICPZ        | DDR driver software MDIC p-impedance override                                                                                                                                                                                                                                                                                                 |
| 6-9<br>DSO_MDICNZ        | DDR driver software MDIC n-impedance override                                                                                                                                                                                                                                                                                                 |
| 10<br>DSO_MDIC_PZ_<br>OE | Driver software override p-impedance output enable                                                                                                                                                                                                                                                                                            |
| 11<br>DSO_MDIC_NZ_<br>OE | Driver software override n-impedance output enable                                                                                                                                                                                                                                                                                            |
| 12–13<br>ODT             | ODT termination value for IOs. This field is combined with DDRCDR_2[ODT] to determine the termination value. Below is the termination based on concatenating these two fields. Note that the order of concatenation is (from left to right) DDRCDR_1[ODT], DDRCDR_2[ODT]  000 75 O 001 55 O 010 60 O 011 50 O 100 150 O 101 43 O 111 Reserved |
| 14<br>DSO_C_EN           | Driver software override enable for address/command                                                                                                                                                                                                                                                                                           |
| 15<br>DSO_D_EN           | Driver software override enable for data                                                                                                                                                                                                                                                                                                      |
| 16–19<br>DSO_CPZ         | DDR driver software command p-impedance override                                                                                                                                                                                                                                                                                              |
| 20-23<br>DSO_CNZ         | DDR driver software command n-impedance override                                                                                                                                                                                                                                                                                              |
| 24–27<br>DSO_DPZ         | Driver software data p-impedance override                                                                                                                                                                                                                                                                                                     |
| 28-31<br>DSO_DNZ         | Driver software data n-impedance override                                                                                                                                                                                                                                                                                                     |

- 1. 0111 provides the target for half-strength mode in both DDR2 (1.8 V) and DDR3 (1.5 V) modes when driver calibration is not used.
- 2. 1011 provides the target for full-strength mode in DDR2 (1.8 V) when driver calibration is not used.
- 3. 1000 provides the target for full-strength mode in DDR3 mode (1.5 V) when driver calibration is not used.

# 8.4.30 DDR Control Driver Register 2 (DDR\_DDRCDR\_2)

The DDRCDR\_2 sets the driver software override enable for clocks and the DDR clocks driver P/N impedance.





### DDR\_DDRCDR\_2 field descriptions

| Field             | Description                                                                                                                                                                                                                                                              |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0<br>DSO_CLK_EN   | Driver software override enable for clocks                                                                                                                                                                                                                               |  |  |  |  |  |
| 1–3               | This field is reserved. Reserved                                                                                                                                                                                                                                         |  |  |  |  |  |
| 4–7<br>DSO_CLKPZ  | Driver software clocks p-impedance override                                                                                                                                                                                                                              |  |  |  |  |  |
| 8-11<br>DSO_CLKNZ | Driver software clocks n-impedance override                                                                                                                                                                                                                              |  |  |  |  |  |
| 12–30<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                         |  |  |  |  |  |
| 31<br>ODT         | ODT termination value for IOs. This field is combined with DDRCDR_1[ODT] to determine the termination value. Below is the termination based on concatenating these two fields. Note that the order of concatenation is (from left to right) DDRCDR_1[ODT], DDRCDR_2[ODT] |  |  |  |  |  |
|                   | 000 75 O                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                   | 001 55 O                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                   | 010 60 O                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                   | 011 50 O                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                   | 100 150 O<br>101 43 O                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                   | 110 120 O                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                   | 111 Reserved                                                                                                                                                                                                                                                             |  |  |  |  |  |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 8.4.31 DDR IP block revision 1 (DDR\_DDR\_IP\_REV1)

The DDR IP block revision 1 register provides read-only fields with the IP block ID, along with major and minor revision information.





#### DDR\_DDR\_IP\_REV1 field descriptions

| Field          | Description                                                |
|----------------|------------------------------------------------------------|
| 0–15<br>IP_ID  | IP block ID. For the DDR controller, this value is 0x0002. |
| 16–23<br>IP_MJ | Major revision. This is currently set to 0x04.             |
| 24–31<br>IP_MN | Minor revision. This is currently set to 0x03.             |

## 8.4.32 DDR IP block revision 2 (DDR\_DDR\_IP\_REV2)

The DDR IP block revision 2 register provides read-only fields with the IP block integration and configuration options.

Address: 2000h base + BFCh offset = 2BFCh



### DDR\_DDR\_IP\_REV2 field descriptions

| Field          | Description                      |
|----------------|----------------------------------|
| 0–7            | This field is reserved. Reserved |
| 8–15<br>IP_INT | IP block integration options     |

### DDR\_DDR\_IP\_REV2 field descriptions (continued)

| Field           | Description                      |
|-----------------|----------------------------------|
| 16–23<br>-      | This field is reserved. Reserved |
| 24–31<br>IP_CFG | IP block configuration options   |

# 8.4.33 Memory data path error injection mask high (DDR\_DATA\_ERR\_INJECT\_HI)

Address: 2000h base + E00h offset = 2E00h



### DDR\_DATA\_ERR\_INJECT\_HI field descriptions

| Field | Description                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EIMH  | Error injection mask high data path  Used to test ECC by forcing errors on the high word of the data path. Setting a bit causes the corresponding data path bit to be inverted on memory bus writes. |

# 8.4.34 Memory data path error injection mask low (DDR\_DATA\_ERR\_INJECT\_LO)

Address: 2000h base + E04h offset = 2E04h



### DDR\_DATA\_ERR\_INJECT\_LO field descriptions

| Fi  | eld | Description                                                                                                                                                    |
|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   |     | Error injection mask low data path                                                                                                                             |
| EII |     | Used to test ECC by forcing errors on the low word of the data path. Setting a bit causes the corresponding data path bit to be inverted on memory bus writes. |

# 8.4.35 Memory data path error injection mask ECC (DDR\_ERR\_INJECT)

The memory data path error injection mask ECC register sets the ECC mask, enables errors to be written to ECC memory, and allows the ECC byte to mirror the most significant data byte. In addition, a single address parity error may be injected through this register.



### DDR\_ERR\_INJECT field descriptions

| Field       | Description                                                                                                                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–14        | This field is reserved. Reserved                                                                                                                                                                                                      |
| 15<br>APIEN | Address parity error injection enable. This bit is cleared by hardware after a single address parity error has been injected.                                                                                                         |
|             | 0 Address parity error injection disabled.                                                                                                                                                                                            |
|             | 1 Address parity error injection enabled.                                                                                                                                                                                             |
| 16–21       | This field is reserved. Reserved                                                                                                                                                                                                      |
| 22<br>EMB   | ECC mirror byte                                                                                                                                                                                                                       |
|             | 0 Mirror byte functionality disabled.                                                                                                                                                                                                 |
|             | 1 Mirror the most significant data path byte onto the ECC byte.                                                                                                                                                                       |
| 23<br>EIEN  | Error injection enable                                                                                                                                                                                                                |
|             | 0 Error injection disabled.                                                                                                                                                                                                           |
|             | 1 Error injection enabled. This applies to the data mask bits, the ECC mask bits, and the ECC mirror bit. Note that error injection should not be enabled until the memory controller has been enabled through DDR_SDRAM_CFG[MEM_EN]. |

### **DDR\_ERR\_INJECT field descriptions (continued)**

| Field | Description                                                                                                        |
|-------|--------------------------------------------------------------------------------------------------------------------|
|       | ECC error injection mask. Setting a mask bit causes the corresponding ECC bit to be inverted on memory bus writes. |

# 8.4.36 Memory data path read capture high (DDR\_CAPTURE\_DATA\_HI)

The memory data path read capture high register stores the high word of the read data path during error capture.

Address: 2000h base + E20h offset = 2E20h



### DDR\_CAPTURE\_DATA\_HI field descriptions

| Field        | Description                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------|
| 0-31<br>ECHD | Error capture high data path. Captures the high word of the data path when errors are detected. |

# 8.4.37 Memory data path read capture low (DDR\_CAPTURE\_DATA\_LO)

The memory data path read capture low register stores the low word of the read data path during error capture.

Address: 2000h base + E24h offset = 2E24h



#### DDR\_CAPTURE\_DATA\_LO field descriptions

| Field        | Description                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------|
| 0–31<br>ECLD | Error capture low data path. Captures the low word of the data path when errors are detected. |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 8.4.38 Memory data path read capture ECC (DDR\_CAPTURE\_ECC)

The memory data path read capture ECC register stores the ECC syndrome bits that were on the data bus when an error was detected.

Address: 2000h base + E28h offset = 2E28h



### DDR\_CAPTURE\_ECC field descriptions

| Field     | Description                                                                             |
|-----------|-----------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                        |
| 16–31     | Error capture ECC. Captures the ECC bits on the data path whenever errors are detected. |
| ECE       | 16:23-8-bit ECC for the 32 bits in beats 0, 2, 4 and 6 in 32-bit bus mode               |
|           | 24:31-8-bit ECC for the 32 bits in beats 1, 3, 5, and 7 in 32-bit bus mode              |

## 8.4.39 Memory error detect (DDR\_ERR\_DETECT)

The memory error detect register stores the detection bits for multiple memory errors, single- and multiple-bit ECC errors, and memory select errors. It is a read/write register. A bit can be cleared by writing a one to the bit. System software can determine the type of memory error by examining the contents of this register. If an error is disabled with ERR\_DISABLE, the corresponding error is never detected or captured in ERR\_DETECT.





#### DDR memory map/register definition



## **DDR\_ERR\_DETECT field descriptions**

| Field     | Description                                                                                                                                                                                                            |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MME  | Multiple memory errors. This bit is cleared by software writing a 1.                                                                                                                                                   |
|           | 0 Multiple memory errors of the same type were not detected.                                                                                                                                                           |
|           | 1 Multiple memory errors of the same type were detected.                                                                                                                                                               |
| 1–22      | This field is reserved. Reserved                                                                                                                                                                                       |
| 23<br>APE | Address parity error. This bit is cleared by software writing a 1.                                                                                                                                                     |
|           | 0 An address parity error has not been detected.                                                                                                                                                                       |
|           | 1 An address parity error has been detected.                                                                                                                                                                           |
| 24<br>ACE | Automatic calibration error. This bit is cleared by software writing a 1.                                                                                                                                              |
|           | 0 An automatic calibration error has not been detected.                                                                                                                                                                |
|           | 1 An automatic calibration error has been detected.                                                                                                                                                                    |
| 25–27     | This field is reserved. Reserved                                                                                                                                                                                       |
| 28<br>MBE | Multiple-bit error. This bit is cleared by software writing a 1.                                                                                                                                                       |
|           | 0 A multiple-bit error has not been detected.                                                                                                                                                                          |
|           | 1 A multiple-bit error has been detected.                                                                                                                                                                              |
| 29<br>SBE | Single-bit ECC error. This bit is cleared by software writing a 1.                                                                                                                                                     |
|           | <ul> <li>The number of single-bit ECC errors detected has not crossed the threshold set in ERR_SBE[SBET].</li> <li>The number of single-bit ECC errors detected crossed the threshold set in ERR_SBE[SBET].</li> </ul> |
| 30 -      | This field is reserved. Reserved                                                                                                                                                                                       |

## **DDR\_ERR\_DETECT** field descriptions (continued)

| Field     | Description                                                       |
|-----------|-------------------------------------------------------------------|
| 31<br>MSE | Memory select error. This bit is cleared by software writing a 1. |
|           | 0 A memory select error has not been detected.                    |
|           | 1 A memory select error has been detected.                        |

## 8.4.40 Memory error disable (DDR\_ERR\_DISABLE)

The memory error disable register allows selective disabling of the DDR controller's error detection circuitry. Disabled errors are not detected or reported.





DDR\_ERR\_DISABLE field descriptions

| Field      | Description                      |
|------------|----------------------------------|
| 0–22<br>-  | This field is reserved. Reserved |
| 23<br>APED | Address parity error disable     |

#### DDR memory map/register definition

## **DDR\_ERR\_DISABLE** field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|            | 0 Address parity errors are detected if DDR_SDRAM_CFG_2[AP_EN] is set. They are reported if ERR_INT_EN[APEE] is set.                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|            | 1 Address parity errors are not detected or reported.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 24<br>ACED | Automatic calibration error disable                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|            | Automatic calibration errors are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|            | 1 Automatic calibration errors are disabled.                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 25–27<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 28<br>MBED | Multiple-bit ECC error disable                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|            | Multiple-bit ECC errors are detected if DDR_SDRAM_CFG[ECC_EN] is set. They are reported if ERR_INT_EN[MBEE] is set. Note that non-correctable read errors cause the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If RFXE is zero and this error occurs, ERR_DISABLE[MBED] must be zero, and ERR_INT_EN[MBEE] and ECC_EN must be one to ensure that an interrupt is generated. |  |  |  |  |
|            | 1 Multiple-bit ECC errors are not detected or reported.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 29<br>SBED | Single-bit ECC error disable                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|            | 0 Single-bit ECC errors are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|            | 1 Single-bit ECC errors are disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 30         | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| -          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 31<br>MSED | Memory select error disable                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|            | 0 Memory select errors are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|            | 1 Memory select errors are disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |

## 8.4.41 Memory error interrupt enable (DDR\_ERR\_INT\_EN)

The memory error interrupt enable register enables ECC interrupts or memory select error interrupts. When an enabled interrupt condition occurs, the internal int signal is asserted to the programmable interrupt controller (PIC).



DDR\_ERR\_INT\_EN field descriptions

| Field      | Description                                                                                                                                                   |  |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0–22<br>-  | This field is reserved. Reserved                                                                                                                              |  |  |  |
| 23<br>APEE | Address parity error interrupt enable  Address parity errors cannot generate interrupts.  Address parity errors generate interrupts.                          |  |  |  |
| 24<br>ACEE | Automatic calibration error interrupt enable  0 Automatic calibration errors cannot generate interrupts.  1 Automatic calibration errors generate interrupts. |  |  |  |
| 25–27<br>- | This field is reserved. Reserved                                                                                                                              |  |  |  |

#### DDR memory map/register definition

# DDR\_ERR\_INT\_EN field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 28<br>MBEE | Multiple-bit ECC error interrupt enable. Note that non-correctable read errors may cause the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled (by clearing HID1[RFXE]). If RFXE is zero and this error occurs, ERR_DISABLE[MBED] must be zero, and ERR_INT_EN[MBEE] and ECC_EN must be one to ensure that an interrupt is generated. |  |  |  |
|            | 0 Multiple-bit ECC errors cannot generate interrupts.                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|            | 1 Multiple-bit ECC errors generate interrupts.                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 29<br>SBEE | Single-bit ECC error interrupt enable                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|            | 0 Single-bit ECC errors cannot generate interrupts.                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|            | 1 Single-bit ECC errors generate interrupts.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 30<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 31<br>MSEE | Memory select error interrupt enable                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|            | 0 Memory select errors do not cause interrupts.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|            | 1 Memory select errors generate interrupts.                                                                                                                                                                                                                                                                                                                                                        |  |  |  |

# 8.4.42 Memory error attributes capture (DDR\_CAPTURE\_ATTRIBUTES)

The memory error attributes capture register sets attributes for errors including type, size, source, and others.





## **DDR\_CAPTURE\_ATTRIBUTES** field descriptions

| Field       | Description                                                                                                     |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|
| 0 -         | This field is reserved. Reserved                                                                                |  |  |  |
| 1–3<br>BNUM | Data beat number. Captures the double-word number for the detected error. Relevant only for ECC errors.         |  |  |  |
| 4 -         | This field is reserved. Reserved                                                                                |  |  |  |
| 5–7<br>TSIZ | Transaction size for the error. Captures the transaction size in double words. Patterns not shown are reserved. |  |  |  |
|             | 000 4 double words 001 1 double word 010 2 double words 011 3 double words                                      |  |  |  |

## **DDR\_CAPTURE\_ATTRIBUTES** field descriptions (continued)

| Field         | Description                                                       |  |  |  |  |
|---------------|-------------------------------------------------------------------|--|--|--|--|
| 8–10          | This field is reserved.                                           |  |  |  |  |
| -             | Reserved                                                          |  |  |  |  |
| 11–15<br>TSRC | Source ID. Specifies the source device mastering the transaction. |  |  |  |  |
|               | 00000 Reserved                                                    |  |  |  |  |
|               | 00001 PCI Express 2                                               |  |  |  |  |
|               | 00010 PCI Express 1                                               |  |  |  |  |
|               | 00011 Reserved                                                    |  |  |  |  |
|               | 00100 Reserved                                                    |  |  |  |  |
|               | 00101 USB                                                         |  |  |  |  |
|               | 00110 Reserved                                                    |  |  |  |  |
|               | 00111 Security                                                    |  |  |  |  |
|               | 01000 Reserved                                                    |  |  |  |  |
|               | 01001 Reserved                                                    |  |  |  |  |
|               | 01010 Boot sequencer                                              |  |  |  |  |
|               | 01011 eSDHC                                                       |  |  |  |  |
|               | 01100 Reserved                                                    |  |  |  |  |
|               | 01101 Reserved                                                    |  |  |  |  |
|               | 01110 Reserved                                                    |  |  |  |  |
|               | 01111 DMA controller (DMAC)                                       |  |  |  |  |
|               | 10000 Processor 0 (instruction)                                   |  |  |  |  |
|               | 10001 Processor 0 (data) 10010 Processor 1 (instruction)          |  |  |  |  |
|               | 10010 Processor 1 (instruction) 10011 Processor 1 (data)          |  |  |  |  |
|               | 10100 QUICC Engine                                                |  |  |  |  |
|               | 10101 DMA                                                         |  |  |  |  |
|               | 10110 Reserved                                                    |  |  |  |  |
|               | 10111 Reserved                                                    |  |  |  |  |
|               | 11000 eTSEC 1                                                     |  |  |  |  |
|               | 11001 eTSEC 2                                                     |  |  |  |  |
|               | 11010 eTSEC 3                                                     |  |  |  |  |
|               | 11011 Reserved                                                    |  |  |  |  |
|               | 11100 Reserved                                                    |  |  |  |  |
|               | 11101 Reserved                                                    |  |  |  |  |
|               | 11110 Reserved                                                    |  |  |  |  |
|               | 11111 Reserved                                                    |  |  |  |  |
| 16–17         | This field is reserved.                                           |  |  |  |  |
| -             | Reserved                                                          |  |  |  |  |
| 18–19<br>TTYP | Transaction type for the error.                                   |  |  |  |  |
|               | 00 Reserved                                                       |  |  |  |  |
|               | 01 Write                                                          |  |  |  |  |
|               | 10 Read                                                           |  |  |  |  |
|               | 11 Read-modify-write                                              |  |  |  |  |
| 20–30         | This field is reserved. Reserved                                  |  |  |  |  |

### DDR\_CAPTURE\_ATTRIBUTES field descriptions (continued)

| Field     | Description                                                                         |  |  |  |
|-----------|-------------------------------------------------------------------------------------|--|--|--|
| 31<br>VLD | Valid. Set as soon as valid information is captured in the error capture registers. |  |  |  |

# 8.4.43 Memory error address capture (DDR\_CAPTURE\_ADDRESS)

The memory error address capture register holds the 32 lsbs of a transaction when a DDR ECC error is detected.

Address: 2000h base + E50h offset = 2E50h



### DDR\_CAPTURE\_ADDRESS field descriptions

| Field         | Description                                                                                  |
|---------------|----------------------------------------------------------------------------------------------|
| 0–31<br>CADDR | Captured address. Captures the 32 lsbs of the transaction address when an error is detected. |

# 8.4.44 Memory error extended address capture (DDR\_CAPTURE\_EXT\_ADDRESS)

The memory error extended address capture register holds the four most significant transaction bits when an error is detected.

Address: 2000h base + E54h offset = 2E54h



#### DDR\_CAPTURE\_EXT\_ADDRESS field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–27  | This field is reserved. |
| -     | Reserved                |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### DDR\_CAPTURE\_EXT\_ADDRESS field descriptions (continued)

| Field           | Description                                                                                         |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| 28–31<br>CEADDR | Captured extended address. Captures the 4 msbs of the transaction address when an error is detected |  |  |  |

# 8.4.45 Single-Bit ECC memory error management (DDR\_ERR\_SBE)

The single-bit ECC memory error management register stores the threshold value for reporting single-bit errors and the number of single-bit errors counted since the last error report. When the counter field reaches the threshold, it wraps back to the reset value (0). If necessary, software must clear the counter after it has managed the error.





### DDR\_ERR\_SBE field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                             |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0–7<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                        |  |  |  |
| 8–15<br>SBET  | ngle-bit error threshold. Establishes the number of single-bit errors that must be detected before an erro<br>andition is reported.                                                                                                                                                                                                     |  |  |  |
| 16–23<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                        |  |  |  |
| 24–31<br>SBEC | Single-bit error counter. Indicates the number of single-bit errors detected and corrected since the last error report. If single-bit error reporting is enabled, an error is reported and a regular or critical interrupt is generated when this value equals SBET. SBEC is automatically cleared when the threshold value is reached. |  |  |  |

## 8.5 Functional description

The DDR SDRAM controller controls processor and I/O interactions with system memory.

It provides support for JEDEC-compliant DDR2 and DDR3 SDRAMs. The memory system allows a wide range of memory devices to be mapped to any arbitrary chip select, and support is provided for registered DIMMs and unbuffered DIMMs. However,

registered DIMMs cannot be mixed with unbuffered DIMMs. In addition, DDR3 DIMM module specifications allow for vendors to use mirrored DIMMs, where some address and bank address lines are mirrored on the DIMM.

The figure below is a high-level block diagram of the DDR memory controller. Requests are received from the internal mastering device and the address is decoded to generate the physical bank, logical bank, row, and column addresses. The transaction is compared with values in the row open table to determine if the address maps to an open page. If the transaction does not map to an open page, an active command is issued.

The memory interface supports the following configurations:

- as many as two physical banks of 32-/40-bit wide memory
- bank sizes up to 4 Gbytes

Programmable parameters allow for a variety of memory organizations and timings. Optional error checking and correcting (ECC) protection is provided for the DDR SDRAM data bus. Using ECC, the DDR memory controller detects and corrects all single/double-bit errors within the data bus, and detects all errors within a nibble. The controller allows as many as 16 pages to be open simultaneously. The amount of time (in clock cycles) the pages remain open is programmable with DDR\_SDRAM\_INTERVAL[BSTOPRE].

#### **Functional description**



Figure 8-53. DDR memory controller block diagram

Read and write accesses to memory are burst oriented; accesses start at a selected location and continue for a programmed number of higher locations (4 or 8) in a programmed sequence. Accesses to closed pages start with the registration of an ACTIVE command followed by a READ or WRITE. (Accessing open pages does not require an ACTIVE command.) The address bits registered coincident with the activate command specifies the logical bank and row to be accessed. The address coincident with the READ or WRITE command specify the logical bank and starting column for the burst access.

The data interface is source synchronous, meaning whatever sources the data also provides a clocking signal to synchronize data reception. These bidirectional data strobes (MDQS[0:3]+ MDQS[8]) are inputs to the controller during reads and outputs during writes. The DDR SDRAM specification requires the data strobe signals to be centered

within the data tenure during writes and to be offset by the controller to the center of the data tenure during reads. This delay is implemented in the controller for both reads and writes.

When ECC is enabled, 1 clock cycle is added to the read path to check ECC and correct single-bit errors. ECC generation does not add a cycle to the write path.

The address and command interface is also source synchronous, although 1/8 cycle adjustments are provided for adjusting the clock alignment.

This figure shows an example of DDR SDRAM configuration with four logical banks.



Figure 8-54. Typical dual data rate SDRAM internal organization

This figure shows some typical signal connections.



Figure 8-55. Typical DDR SDRAM interface signals

Figure 8-56 shows an example DDR SDRAM configuration with two physical banks each comprised of four 8Mbyte x 8 DDR modules for a total of 128 Mbytes of system memory. One of the five modules is used for the memory's ECC checking function. Certain address and control lines may require buffering. Analysis of the device's AC timing specifications, desired memory operating frequency, capacitive loads, and board routing loads can assist the system designer in deciding signal buffering requirements. The DDR memory controller drives 16 address pins, but in this example the DDR SDRAM devices use only 12 bits.



- 1. All signals are connected in common (in parallel) except for MCS[0:1], MCK, MDM[0:3], and the data bus signals.
- Each of the MCS[0:1] signals correspond with a separate physical bank of memory.
- 3. Buffering may be needed if large memory arrays are used.

Figure 8-56. Example 64-Mbyte DDR SDRAM configuration with ECC

Error management explains how the DDR memory controller handles errors.

## 8.5.1 DDR SDRAM interface operation

The DDR memory controller supports many different DDR SDRAM configurations. SDRAMs with different sizes can be used in the same system.

Sixteen multiplexed address signals and three logical bank select signals support device densities from 32 Mbits to 8 Gbits. Two chip select  $(\overline{CS})$  signals support up to two DIMMs of memory. The DDR SDRAM physical banks can be built from standard memory modules or directly-attached memory devices. The data path to individual physical banks is up to 32-bits wide, 40 bits with ECC. The DDR memory controller supports physical bank sizes from 32 Mbytes to 4 Gbytes. The physical banks can be constructed using  $\times 8$ ,  $\times 16$ , or  $\times 32$  memory devices. The memory densities supported are 64 Mbits, 128 Mbits, 256 Mbits, 512 Mbits, 1 Gbit, 2 Gbits, 4 Gbits and 8 Gbits. Five data mask (DM) signals provide byte selection for memory accesses.

#### **NOTE**

An 8-bit DDR SDRAM device has a DQM signal and eight data signals (DQ[0:7]). A 16-bit DDR SDRAM device has two DQM signals associated with specific halves of the 16 data signals (DQ[0:7] and DQ[8:15]).

When ECC is enabled, all memory accesses are performed on double-word boundaries (that is, all DQM signals are set simultaneously). However, when ECC is disabled, the memory system uses the DQM signals for byte lane selection.

The table below shows the DDR memory controller's relationships between data byte lane 0-3, MDM[0:3], MDQS[0:3], and MDQ[0:31] when DDR SDRAM memories are used with x8 or x16 devices.

| Data byte lane | Data bus mask | Data bus strobe | Data bus   |
|----------------|---------------|-----------------|------------|
| 0 (MSB)        | MDM[0]        | MDQS[0]         | MDQ[0:7]   |
| 1              | MDM[1]        | MDQS[1]         | MDQ[8:15]  |
| 2              | MDM[2]        | MDQS[2]         | MDQ[16:23] |
| 3              | MDM[3]        | MDQS[3]         | MDQ[24:31] |

Table 8-58. Byte lane to data relationship

## 8.5.1.1 Supported DDR SDRAM organizations

Although the DDR memory controller multiplexes row and column address bits onto 16 memory address signals and 3 logical bank select signals, a physical bank may be implemented with memory devices requiring fewer than 31 address bits.

The physical bank may be configured to provide from 12 to 16 row address bits, plus 2 or 3 logical bank-select bits and from 8-11 column address bits.

The following tables describe DDR SDRAM device configurations supported by the DDR memory controller.

# NOTE DDR SDRAM is limited to 30 total address bits.

Table 8-59. Supported DDR2 SDRAM device configurations

| SDRAM device | Device configuration | Row x column x sub-<br>bank bits | 32-Bit bank size | Two banks of memory |
|--------------|----------------------|----------------------------------|------------------|---------------------|
| 256 Mbits    | 32 Mbits x 8         | 13 x 10 x 2                      | 128 Mbytes       | 256 Mbytes          |
| 256 Mbits    | 16 Mbits x 16        | 13 x 9 x 2                       | 64 Mbytes        | 128 Mbytes          |
| 512 Mbits    | 64 Mbits x 8         | 14 x 10 x 2                      | 256 Mbytes       | 512 Mbytes          |
| 512 Mbits    | 32 Mbits x 16        | 13 x 10 x 2                      | 128 Mbytes       | 256 Mbytes          |
| 1 Gbits      | 128 Mbits x 8        | 14 x 10 x 3                      | 512 Mbytes       | 1 Gbyte             |
| 1 Gbits      | 64 Mbits x 16        | 13 x 10 x 3                      | 256 Mbytes       | 512 Mbytes          |
| 2 Gbits      | 256 Mbits x 8        | 15 x 10 x 3                      | 1 Gbyte          | 2 Gbytes            |
| 2 Gbits      | 128 Mbits x 16       | 14 x 10 x 3                      | 512 Mbytes       | 1 Gbyte             |
| 4 Gbits      | 512 Mbits x 8        | 15 x 11 x 3                      | 2 Gbytes         | 4 Gbytes            |
| 4 Gbits      | 256 Mbits x 16       | 15 x 10 x 3                      | 1 Gbyte          | 2 Gbytes            |

Table 8-60. Supported DDR3 SDRAM device configurations (32-bit data)

| SDRAM device | Device configuration | Row x column<br>x sub-bank<br>bits | 32-bit bank size | Two Banks of memory |
|--------------|----------------------|------------------------------------|------------------|---------------------|
| 512 Mbits    | 64 Mbits x 8         | 13 x 10 x 3                        | 256 Mbytes       | 512 Mbytes          |
| 512 Mbits    | 32 Mbits x 16        | 12 x 10 x 2                        | 128 Mbytes       | 256 Mbytes          |
| 1 Gbits      | 128 Mbits x 8        | 14 x 10 x 3                        | 512 Mbytes       | 1 Gbyte             |
| 1 Gbits      | 64 Mbits x 16        | 13 x 10 x 3                        | 256 Mbytes       | 512 Mbytes          |
| 2 Gbits      | 256 Mbits x 8        | 15 x 10 x 3                        | 1 Gbyte          | 2 Gbytes            |
| 2 Gbits      | 128 Mbits x 16       | 14 x 10 x 3                        | 512 Mbytes       | 1 Gbyte             |
| 4 Gbits      | 512 Mbits x 8        | 16 x 10 x 3                        | 2 Gbytes         | 4 Gbytes            |
| 4 Gbits      | 256 Mbits x 16       | 15 x 10 x 3                        | 1 Gbyte          | 2 Gbytes            |
| 8 Gbits      | 1 Gbit x 8           | 16 x 11 x 3                        | 4 Gbytes         | 8 Gbytes            |
| 8 Gbits      | 512 Mbits x 16       | 16 x 10 x 3                        | 2 Gbytes         | 4 Gbytes            |

#### **Functional description**

If a transaction request is issued to the DDR memory controller and the address does not lie within any of the programmed address ranges for an enabled chip select, a memory select error is flagged. Errors are described in detail in Error management.

Using a memory-polling algorithm at power-on reset or by querying the JEDEC serial presence detect capability of memory modules, system firmware uses the memory-boundary registers to configure the DDR memory controller to map the size of each bank in memory. The memory controller uses its bank map to assert the appropriate MCS\_Bn signal for memory accesses according to the provided bank starting and ending addresses. The memory banks are not required to be mapped to a contiguous address space.

## 8.5.2 DDR SDRAM address multiplexing

The following tables show the address bit encodings for each DDR SDRAM configuration.

The address presented at the memory controller signals MA[15:0] use MA[15] as the msb and MA[0] as the lsb. Also, MA[10] is used as the auto-precharge bit in DDR2/DDR3 modes for reads and writes, so the column address can never use MA[10].

Table 8-61. DDR2/DDR3 Address multiplexing for 32-bit data bus with interleaving and partial array self-refresh disabled

|                | ow                   | ms<br>b |        |        |        |        |        |    |   |     |   |     | A      | ddr | ess    | fro    | m ( | Cor | e N | last | ter |        |        |        |        |        |     |        |   |   |   | lsb       |
|----------------|----------------------|---------|--------|--------|--------|--------|--------|----|---|-----|---|-----|--------|-----|--------|--------|-----|-----|-----|------|-----|--------|--------|--------|--------|--------|-----|--------|---|---|---|-----------|
|                | x<br>Col             | 4       | 5      | 6      | 7      | 8      | 9      | 1  | 1 | 1 2 | 1 | 1 4 | 1<br>5 | 1 6 | 1<br>7 | 1<br>8 | 1   | 2   |     | 2 2  | 2   | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2<br>8 | 2 9 | 3<br>0 |   |   |   | 34-3<br>5 |
| 16 x<br>10 x 3 | MRA<br>S_B           |         | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 10 | 9 | 8   | 7 | 6   | 5      | 4   | 3      | 2      | 1   | 0   |     |      |     |        |        |        |        |        |     |        |   |   |   |           |
|                | MBA                  |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     | 2   | 1    | 0   |        |        |        |        |        |     |        |   |   |   |           |
|                | MCA<br>S_B           |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     |     |      |     | 9      | 8      | 7      | 6      | 5      | 4   | 3      | 2 | 1 | 0 |           |
| 15 x<br>10 x 3 | 5 x MRA<br>0 x 3 S_B |         |        | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 10 | 9 | 8   | 7 | 6   | 5      | 4   | 3      | 2      | 1   | 0   |     |      |     |        |        |        |        |        |     |        |   |   |   |           |
|                | MBA                  |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     | 2   | 1    | 0   |        |        |        |        |        |     |        |   |   |   |           |
|                | MCA<br>S_B           |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     |     |      |     | 9      | 8      | 7      | 6      | 5      | 4   | 3      | 2 | 1 | 0 |           |
| 14 x<br>10 x 3 | MRA<br>S_B           |         |        |        | 1<br>3 | 1<br>2 | 1<br>1 | 10 | 9 | 8   | 7 | 6   | 5      | 4   | 3      | 2      | 1   | 0   |     |      |     |        |        |        |        |        |     |        |   |   |   |           |
|                | MBA                  |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     | 2   | 1    | 0   |        |        |        |        |        |     |        |   |   |   |           |
|                | MCA<br>S_B           |         |        |        |        |        |        |    |   |     |   |     |        |     |        |        |     |     |     |      |     | 9      | 8      | 7      | 6      | 5      | 4   | 3      | 2 | 1 | 0 |           |

Table 8-61. DDR2/DDR3 Address multiplexing for 32-bit data bus with interleaving and partial array self-refresh disabled (continued)

|                | ow<br>x    | ms<br>b |   |   |   |        |        |        |        |        |     |        | Α      | ddr    | ess    | fro | m (    | Cor    | e N | las | ter |        |        |        |        |        |        |        |   |        |   | lsb       |
|----------------|------------|---------|---|---|---|--------|--------|--------|--------|--------|-----|--------|--------|--------|--------|-----|--------|--------|-----|-----|-----|--------|--------|--------|--------|--------|--------|--------|---|--------|---|-----------|
|                | ol         | 4       | 5 | 6 | 7 | 8      | 9      | 1<br>0 | 1      | 1 2    | 1 3 | 1<br>4 | 1<br>5 | 1<br>6 | 1<br>7 |     | 1<br>9 | 2<br>0 |     |     | 2   | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2<br>8 | 2<br>9 | 3<br>0 |   | 3<br>2 |   | 34-3<br>5 |
| 14 x<br>10 x 2 | MRA<br>S_B |         |   |   |   | 1<br>3 | 1<br>2 | 11     | 1<br>0 | 9      | 8   | 7      | 6      | 5      | 4      | 3   | 2      | 1      | 0   |     |     |        |        |        |        |        |        |        |   |        |   |           |
|                | MBA        |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     | 1   | 0   |        |        |        |        |        |        |        |   |        |   |           |
|                | MCA<br>S_B |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     |     |     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2 | 1      | 0 |           |
| 13 x<br>10 x 3 | MRA<br>S_B |         |   |   |   | 1<br>2 | 1<br>1 | 10     | 9      | 8      | 7   | 6      | 5      | 4      | 3      | 2   | 1      | 0      |     |     |     |        |        |        |        |        |        |        |   |        |   |           |
|                | MBA        |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        | 2   | 1   | 0   |        |        |        |        |        |        |        |   |        |   |           |
|                | MCA<br>S_B |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     |     |     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2 | 1      | 0 |           |
| 13 x<br>10 x 2 | MRA<br>S_B |         |   |   |   |        | 1<br>2 | 11     | 1<br>0 | 9      | 8   | 7      | 6      | 5      | 4      | 3   | 2      | 1      | 0   |     |     |        |        |        |        |        |        |        |   |        |   |           |
|                | MBA        |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     | 1   | 0   |        |        |        |        |        |        |        |   |        |   |           |
|                | MCA<br>S_B |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     |     |     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2 | 1      | 0 |           |
| 13 x 9<br>x 2  | MRA<br>S_B |         |   |   |   |        |        | 12     | 1      | 1<br>0 | 9   | 8      | 7      | 6      | 5      | 4   | 3      | 2      | 1   | 0   |     |        |        |        |        |        |        |        |   |        |   |           |
|                | MBA        |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     |     | 1   | 0      |        |        |        |        |        |        |   |        |   |           |
|                | MCA<br>S_B |         |   |   |   |        |        |        |        |        |     |        |        |        |        |     |        |        |     |     |     |        | 8      | 7      | 6      | 5      | 4      | 3      | 2 | 1      | 0 |           |

Table 8-62. DDR2/DDR3 Address multiplexing for 16-bit data bus

|                       | s<br>b |   |                                                 |          |            |              |                |                                                                 |                                                                                                                                  |                                                                            |                               |                                                 | Ad                                              | ldre                                                                        | ss f                                            | ron                                             | n Co                                            | ore                                                                                                                                                                               | Mas                                                                                                                                     | ter                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                    |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   | ls<br>b                                           |
|-----------------------|--------|---|-------------------------------------------------|----------|------------|--------------|----------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------|-------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|
| ol                    | 4      | 5 | 6                                               | 7        | 8          | 9            | 1<br>0         | 1                                                               | 1 2                                                                                                                              | 1                                                                          | 1<br>4                        | 1<br>5                                          | 1<br>6                                          | 1<br>7                                                                      | 1<br>8                                          | 1<br>9                                          | 2<br>0                                          | 2                                                                                                                                                                                 | 2 2                                                                                                                                     | 2                                                                                                                                                                                                                     | 2<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2<br>5                                             | 2<br>6                                            | 2<br>7                                            | 2<br>8                                            | 2<br>9                                            | 3<br>0                                            | 3                                                 | 3 2                                               | 3                                                 | 3<br>4                                            | 3<br>5                                            |
| M<br>R<br>A<br>S<br>B |        |   |                                                 | 14       | 13         | 12           | 11             | 10                                                              | 9                                                                                                                                | 8                                                                          | 7                             | 6                                               | 5                                               | 4                                                                           | 3                                               | 2                                               | 1                                               | 0                                                                                                                                                                                 | 0                                                                                                                                       |                                                                                                                                                                                                                       | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                    |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |
| M<br>B<br>A           |        |   |                                                 |          |            |              |                |                                                                 |                                                                                                                                  |                                                                            |                               |                                                 |                                                 |                                                                             |                                                 |                                                 |                                                 |                                                                                                                                                                                   | 2                                                                                                                                       | 1                                                                                                                                                                                                                     | O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                    |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |                                                   |
| M<br>C<br>A<br>S      |        |   |                                                 |          |            |              |                |                                                                 |                                                                                                                                  |                                                                            |                               |                                                 |                                                 |                                                                             |                                                 |                                                 |                                                 |                                                                                                                                                                                   |                                                                                                                                         |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 9                                                  | 8                                                 | 7                                                 | 6                                                 | 5                                                 | 4                                                 | 3                                                 | 2                                                 | 1                                                 | 0                                                 |                                                   |
|                       |        | 4 | 4 5 MM RAA SS A MM CAA SS A SS A SS A SS A SS A | 4 5 6  M | 4 5 6 7  M | 4 5 6 7 8  M | 4 5 6 7 8 9  M | 4 5 6 7 8 9 1 0 M 14 13 12 11 A A A A A A A A A A A A A A A A A | 4 5 6 7 8 9 1 1<br>0 1<br>M 14 13 12 11 10<br>A 5<br>B 4<br>M 18 A 18 B 18 B 1 1 1 10<br>B 18 B 18 | 4 5 6 7 8 9 1 1 1 2 M 14 13 12 11 10 9 A A A A A A A A A A A A A A A A A A | 4 5 6 7 8 9 1 1 1 1 1 1 3 3 M | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 6 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 3 4 5 6 7 8 9 0 0 1 2 3 4 5 6 7 8 9 0 0 1 2 3 4 5 6 7 8 9 0 0 1 2 3 4 5 6 7 8 9 0 0 1 2 3 4 5 6 7 8 9 0 0 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 3 4 5 6 7 8 9 0 1 1 1 1 1 1 1 1 1 1 1 1 1 2 2 3 4 5 6 7 8 9 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 2 3 4 5 6 7 8 9 0 1 2 2 3 4 5 6 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 6 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 2 3 3 4 5 7 8 9 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 3 4  M | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 | 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 |

Table 8-62. DDR2/DDR3 Address multiplexing for 16-bit data bus (continued)

| 1                       | ow<br>x               | m<br>s<br>b |   |   |   |    |    |    |    |     |   |     |   | Ac     | ldre | ess | fron | n Co | ore | Mas | ster |        |        |        |     |        |        |   |   |        |   |   | ls<br>b |
|-------------------------|-----------------------|-------------|---|---|---|----|----|----|----|-----|---|-----|---|--------|------|-----|------|------|-----|-----|------|--------|--------|--------|-----|--------|--------|---|---|--------|---|---|---------|
| C                       | ol                    | 4           | 5 | 6 | 7 | 8  | 9  | 1  | 1  | 1 2 | 1 | 1 4 |   | 1<br>6 | 1 7  | 1 8 | 1 9  | 2    | 2   | 2 2 | 2    | 2<br>4 | 2<br>5 | 2<br>6 | 2 7 | 2<br>8 | 2<br>9 | 3 | 3 | 3<br>2 | 3 | 3 | 3<br>5  |
| x<br>10                 |                       |             |   |   |   | 13 | 12 | 11 | 10 | 9   | 8 | 7   | 6 | 5      | 4    | 3   | 2    | 1    | 0   |     |      |        |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>B<br>A           |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     | 2   | 1    | 0      |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>C<br>A<br>S      |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     |     |      |        | 9      | 8      | 7   | 6      | 5      | 4 | 3 | 2      | 1 | 0 |         |
| x<br>10                 | B<br>M<br>R<br>A<br>S |             |   |   |   |    | 13 | 12 | 11 | 10  | 9 | 8   | 7 | 6      | 5    | 4   | 3    | 2    | 1   | 0   |      |        |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>B<br>A           |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     |     | 1    | 0      |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>C<br>A<br>S      |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     |     |      |        | 9      | 8      | 7   | 6      | 5      | 4 | 3 | 2      | 1 | 0 |         |
| 13<br>x<br>10<br>x<br>3 | M<br>R<br>A<br>S      |             |   |   |   |    | 12 | 11 | 10 | 9   | 8 | 7   | 6 | 5      | 4    | 3   | 2    | 1    | 0   |     |      |        |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>B<br>A           |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     | 2   | 1    | 0      |        |        |     |        |        |   |   |        |   |   |         |
|                         | M<br>C<br>A<br>S      |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     |     |      |        | 9      | 8      | 7   | 6      | 5      | 4 | 3 | 2      | 1 | 0 |         |
|                         | B                     |             |   |   |   |    |    |    |    |     |   |     |   |        |      |     |      |      |     |     |      |        |        |        |     |        |        |   |   |        |   |   |         |

Table 8-62. DDR2/DDR3 Address multiplexing for 16-bit data bus (continued)



Chip select interleaving is supported for the memory controller, and is programmed in DDR\_SDRAM\_CFG[BA\_INTLV\_CTL]. Interleaving is supported between chip selects 0 and 1. When interleaving is enabled, the chip selects being interleaved must use the same size of memory. One extra bit in the address decode is used for the interleaving to determine which chip select to access.

The following tables show examples of interleaving between chip selects.

Table 8-63. Example of address multiplexing for 32-bit data bus interleaving between two banks with partial array self refresh disabled

|                         | ow<br>x                | m<br>s<br>b |    |    |    |    |     |   |     |     |     |        | A   | ddre | ess | fron | n Co              | ore I             | Mas | ter |        |        |        |        |        |   |   |   |     |   | ls<br>b           |
|-------------------------|------------------------|-------------|----|----|----|----|-----|---|-----|-----|-----|--------|-----|------|-----|------|-------------------|-------------------|-----|-----|--------|--------|--------|--------|--------|---|---|---|-----|---|-------------------|
| C                       | ol                     | 5           | 6  | 7  | 8  | 9  | 1 0 | 1 | 1 2 | 1 3 | 1 4 | 1<br>5 | 1 6 | 1 7  | 1 8 | 1 9  | 2 0               | 2                 | 2 2 | 2 3 | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2<br>8 | 9 | 3 | 3 | 3 2 | 3 | 3<br>4-<br>3<br>5 |
| 14<br>x<br>10<br>x<br>3 | M<br>R<br>A<br>S_<br>B |             | 13 | 12 | 11 | 10 | 9   | 8 | 7   | 6   | 5   | 4      | 3   | 2    | 1   | 0    | C<br>S<br>S<br>EL |                   |     |     |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A            |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   | 2                 | 1   | 0   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S_<br>B |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   |                   |     |     | 9      | 8      | 7      | 6      | 5      | 4 | 3 | 2 | 1   | 0 |                   |
| 14<br>x<br>10<br>x<br>2 | M<br>R<br>A<br>S_<br>B |             |    | 13 | 12 | 11 | 10  | 9 | 8   | 7   | 6   | 5      | 4   | 3    | 2   | 1    | 0                 | C<br>S<br>S<br>EL |     |     |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A            |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   |                   | 1   | 0   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S_<br>B |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   |                   |     |     | 9      | 8      | 7      | 6      | 5      | 4 | 3 | 2 | 1   | 0 |                   |
| 13<br>x<br>10<br>x<br>3 | M<br>R<br>A<br>S_<br>B |             |    | 12 | 11 | 10 | 9   | 8 | 7   | 6   | 5   | 4      | 3   | 2    | 1   | 0    | C<br>S<br>S<br>EL |                   |     |     |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A            |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   | 2                 | 1   | 0   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S_<br>B |             |    |    |    |    |     |   |     |     |     |        |     |      |     |      |                   |                   |     |     | 9      | 8      | 7      | 6      | 5      | 4 | 3 | 2 | 1   | 0 |                   |

Table 8-63. Example of address multiplexing for 32-bit data bus interleaving between two banks with partial array self refresh disabled (continued)



Partial array self-refresh (PASR) can be enabled for any chip select using the CSn\_CONFIG\_2[PASR\_CFG] fields. If PASR is enabled for a given chip select, then the sub-bank and row decode is swapped, and the sub-bank is decoded as the most significant portion of the DRAM address, as shown in the table below. If chip select interleaving and PASR are enabled for a chip select, then the interleaved chip select bit is placed immediately to the left of the column decode, as shown in Table 8-65.

Table 8-64. Address multiplexing with partial array self refresh Enabled

| R                       | ow               | m      |   |   |   |    |    |    |    |     |    |     |        |        |     |        |        | Core |   |     | r |        |        |        |        |        |   |   |   |     |   | Is                |
|-------------------------|------------------|--------|---|---|---|----|----|----|----|-----|----|-----|--------|--------|-----|--------|--------|------|---|-----|---|--------|--------|--------|--------|--------|---|---|---|-----|---|-------------------|
|                         | x                | s<br>b |   |   |   |    |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   |        |        |        |        |        |   |   |   |     |   | b                 |
| C                       | ol               | 4      | 5 | 6 | 7 | 8  | 9  | 1  | 1  | 1 2 | 1  | 1 4 | 1<br>5 | 1<br>6 | 1 7 | 1<br>8 | 1<br>9 | 0    | 1 | 2 2 | 3 | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2<br>8 | 9 | 3 | 3 | 3 2 | 3 | 3<br>4-<br>3<br>5 |
| 16<br>x<br>10<br>x<br>3 | M<br>R<br>A<br>S |        |   |   |   | 15 | 14 | 13 | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3    | 2 | 1   | 0 |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A      |        | 2 | 1 | 0 |    |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M C A S   B      |        |   |   |   |    |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   | 9      | 8      | 7      | 9      | 5      | 4 | З | 2 | 1   | 0 |                   |
| 15<br>x<br>10<br>x<br>3 | M<br>R<br>A<br>S |        |   |   |   |    | 14 | 13 | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3    | 2 | 1   | 0 |        |        |        |        |        |   |   |   |     |   |                   |
| 3                       | B<br>M<br>B<br>A |        |   | 2 | 1 | 0  |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S |        |   |   |   |    |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   | 9      | 8      | 7      | 6      | 5      | 4 | 3 | 2 | 1   | 0 |                   |
| 14<br>x<br>10<br>x<br>3 | R                |        |   |   |   |    |    | 13 | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3    | 2 | 1   | 0 |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A      |        |   |   | 2 | 1  | 0  |    |    |     |    |     |        |        |     |        |        |      |   |     |   |        |        |        |        |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S |        |   |   |   |    |    |    |    |     |    |     |        |        |     |        |        |      |   |     |   | 9      | 8      | 7      | 6      | 5      | 4 | 3 | 2 | 1   | 0 |                   |

Table 8-64. Address multiplexing with partial array self refresh Enabled (continued)

| R                       | ow               | m      |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        | Cor    |   |   |   |        |        |        |   |        |   | - |   |     |   | Is                |
|-------------------------|------------------|--------|---|---|---|---|---|----|----|-----|----|-----|--------|--------|-----|--------|--------|--------|---|---|---|--------|--------|--------|---|--------|---|---|---|-----|---|-------------------|
|                         | X                | s<br>b |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        |        |   |   |   |        |        |        |   |        |   |   |   |     |   | b                 |
|                         | ol               | 4      | 5 | 6 | 7 | 8 | 9 | 1  | 1  | 1 2 | 1  | 1 4 | 1<br>5 | 1<br>6 | 1 7 | 1<br>8 | 1<br>9 | 2<br>0 | 1 | 2 | 3 | 2<br>4 | 2<br>5 | 2<br>6 | 7 | 2<br>8 | 9 | 3 | 3 | 3 2 | 3 | 3<br>4-<br>3<br>5 |
| х                       | M<br>R<br>A<br>S |        |   |   |   |   |   | 13 | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3      | 2 | 1 | 0 |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A      |        |   |   |   | 1 | 0 |    |    |     |    |     |        |        |     |        |        |        |   |   |   |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S |        |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        |        |   |   |   | 9      | 8      | 7      | 6 | 5      | 4 | 3 | 2 | 1   | 0 |                   |
| x                       | M<br>R<br>A<br>S |        |   |   |   |   |   |    | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3      | 2 | 1 | 0 |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A      |        |   |   |   | 2 | 1 | 0  |    |     |    |     |        |        |     |        |        |        |   |   |   |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S |        |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        |        |   |   |   | 9      | 8      | 7      | 6 | 5      | 4 | 3 | 2 | 1   | 0 |                   |
| 13<br>x<br>10<br>x<br>2 | M<br>R<br>A<br>S |        |   |   |   |   |   |    | 12 | 11  | 10 | 9   | 8      | 7      | 6   | 5      | 4      | 3      | 2 | 1 | 0 |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>B<br>A      |        |   |   |   |   | 1 | 0  |    |     |    |     |        |        |     |        |        |        |   |   |   |        |        |        |   |        |   |   |   |     |   |                   |
|                         | M<br>C<br>A<br>S |        |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        |        |   |   |   | 9      | 8      | 7      | 6 | 5      | 4 | 3 | 2 | 1   | 0 |                   |
|                         | B                |        |   |   |   |   |   |    |    |     |    |     |        |        |     |        |        |        |   |   |   |        |        |        |   |        |   |   |   |     |   |                   |

Table 8-64. Address multiplexing with partial array self refresh Enabled (continued)

|                   | ow<br>x          | m<br>s<br>b |   |   |   |   |   |     |   |     |    |     | ı      | Add    | lres   | s fro  | om (   | Core | e Ma | aste | er  |        |            |        |   |        |   |   |   |     |   | ls<br>b |
|-------------------|------------------|-------------|---|---|---|---|---|-----|---|-----|----|-----|--------|--------|--------|--------|--------|------|------|------|-----|--------|------------|--------|---|--------|---|---|---|-----|---|---------|
| C                 | ol               | 4           | 5 | 6 | 7 | 8 | 9 | 1 0 | 1 | 1 2 | 1  | 1 4 | 1<br>5 | 1<br>6 | 1<br>7 | 1<br>8 | 1<br>9 |      | 2    | 2 2  | 2 3 | 2<br>4 | <b>2 5</b> | 2<br>6 | 7 | 2<br>8 | 9 | 3 | 3 | 3 2 |   |         |
| 13<br>x<br>9<br>x | M<br>R<br>A<br>S |             |   |   |   |   |   |     |   | 12  | 11 | 10  | 9      | 8      | 7      | 6      | 5      | 4    | 3    | 2    | 1   | 0      |            |        |   |        |   |   |   |     |   |         |
| 2                 | B                |             |   |   |   |   |   |     |   |     |    |     |        |        |        |        |        |      |      |      |     |        |            |        |   |        |   |   |   |     |   |         |
|                   | M<br>B<br>A      |             |   |   |   |   |   | 1   | 0 |     |    |     |        |        |        |        |        |      |      |      |     |        |            |        |   |        |   |   |   |     |   |         |
|                   | M<br>C<br>A<br>S |             |   |   |   |   |   |     |   |     |    |     |        |        |        |        |        |      |      |      |     |        | 8          | 7      | 6 | 5      | 4 | 3 | 2 | 1   | 0 |         |
|                   | _<br>B           |             |   |   |   |   |   |     |   |     |    |     |        |        |        |        |        |      |      |      |     |        |            |        |   |        |   |   |   |     |   |         |

Table 8-65. Example of address multiplexing for 32 -bit data bus interleaving between two banks with partial array self refresh enabled

| R          | ow         | ms |   |   |   |        |        |        |        |     |     |     | A | \dd | res | s fr | om | Со | re I | Maste    | er |     |   |     |   |   |   |   |     |   | lsb   |
|------------|------------|----|---|---|---|--------|--------|--------|--------|-----|-----|-----|---|-----|-----|------|----|----|------|----------|----|-----|---|-----|---|---|---|---|-----|---|-------|
|            | x<br>Col   | 5  | 6 | 7 | 8 | 9      | 1 0    | 1      | 1 2    | 1 3 | 1 4 | 1 5 | 1 | 1 7 | 1 8 | 1    | 2  | 2  | 2 2  | 23       | 2  | 2 5 | 2 | 2 7 | 2 | 2 | 3 |   | 3 2 | 3 | 34-35 |
| 14 x<br>10 | MRAS<br>_B |    |   |   |   | 1      | 1 2    | 1      | 1      | 9   | 8   | 7   | 6 | 5   | 4   | 3    | 2  | 1  | 0    | CS<br>SE |    | •   |   |     |   | , |   | - | _   | , |       |
| x3         | MBA        |    | 2 | 1 | 0 |        |        |        |        |     |     |     |   |     |     |      |    |    |      | L        |    |     |   |     |   |   |   |   |     |   |       |
|            | MCAS<br>_B |    |   |   |   |        |        |        |        |     |     |     |   |     |     |      |    |    |      |          | 9  | 8   | 7 | 6   | 5 | 4 | 3 | 2 | 1   | 0 |       |
| 14 x<br>10 | MRAS<br>_B |    |   |   |   | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9   | 8   | 7   | 6 | 5   | 4   | 3    | 2  | 1  | 0    | CS<br>SE |    |     |   |     |   |   |   |   |     |   |       |
| x 2        | MBA        |    |   | 1 | 0 |        |        |        |        |     |     |     |   |     |     |      |    |    |      | L        |    |     |   |     |   |   |   |   |     |   |       |
|            | MCAS<br>_B |    |   |   |   |        |        |        |        |     |     |     |   |     |     |      |    |    |      |          | 9  | 8   | 7 | 6   | 5 | 4 | 3 | 2 | 1   | 0 |       |
| 13 x<br>10 | MRAS<br>_B |    |   |   |   |        | 1<br>2 | 1<br>1 | 1<br>0 | 9   | 8   | 7   | 6 | 5   | 4   | 3    | 2  | 1  | 0    | CS<br>SE |    |     |   |     |   |   |   |   |     |   |       |
| x 3        | MBA        |    |   | 2 | 1 | 0      |        |        |        |     |     |     |   |     |     |      |    |    |      | L        |    |     |   |     |   |   |   |   |     |   |       |
|            | MCAS<br>_B |    |   |   |   |        |        |        |        |     |     |     |   |     |     |      |    |    |      |          | 9  | 8   | 7 | 6   | 5 | 4 | 3 | 2 | 1   | 0 |       |

Table 8-65. Example of address multiplexing for 32 -bit data bus interleaving between two banks with partial array self refresh enabled (continued)

| R          | ow         | ms<br>b |   |   |   |   |     |          |   |   |   |   | P | ۸dd | res | s fr | om | Со | re I | Vlaste   | er |   |   |   |   |   |   |   |   |   | Isb   |
|------------|------------|---------|---|---|---|---|-----|----------|---|---|---|---|---|-----|-----|------|----|----|------|----------|----|---|---|---|---|---|---|---|---|---|-------|
| 1          | x<br>Col   | 5       | 6 | 7 | 8 | 9 | 1   | 1        | 1 | 1 | 1 | 1 | 1 | 1   | 1   | 1    | 2  | 2  | 2    | 23       | 2  | 2 | 2 | 2 | 2 | _ |   | 3 |   | 3 | 34-35 |
|            |            |         |   |   |   |   | U   | <u>'</u> | 2 | 3 | 4 | 5 | 6 | ′   | 8   | 9    | 0  | 1  | 2    |          | 4  | 5 | 6 | 7 | 8 | 9 | 0 | 1 | 2 | 3 |       |
| 13 x<br>10 | MRAS<br>_B |         |   |   |   |   | 1 2 | 1        | 1 | 9 | 8 | 7 | 6 | 5   | 4   | 3    | 2  | 1  | 0    | CS<br>SE |    |   |   |   |   |   |   |   |   |   |       |
| x 2        | MBA        |         |   |   | 1 | 0 |     |          |   |   |   |   |   |     |     |      |    |    |      | -        |    |   |   |   |   |   |   |   |   |   |       |
|            | MCAS<br>_B |         |   |   |   |   |     |          |   |   |   |   |   |     |     |      |    |    |      |          | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |       |

#### 8.5.3 JEDEC standard DDR SDRAM interface commands

The following section describes the commands and timings the controller uses when operating in DDR3 or DDR2 modes.

All read or write accesses to DDR SDRAM are performed by the DDR memory controller using JEDEC standard DDR SDRAM interface commands. The SDRAM device samples command and address inputs on rising edges of the memory clock; data is sampled using both the rising and falling edges of DQS. Data read from the DDR SDRAM is also sampled on both edges of DQS.

The following DDR SDRAM interface commands (summarized in the table below) are provided by the DDR controller. All actions for these commands are described from the perspective of the SDRAM device.

- Row activate-Latches row address and initiates memory read of that row. Row data is latched in SDRAM sense amplifiers and must be restored by a precharge command before another row activate occurs.
- Precharge-Restores data from the sense amplifiers to the appropriate row. Also initializes the sense amplifiers in preparation for reading another row in the memory array (performing another activate command). Precharge must occur after read or write, if the row address changes on the next open page mode access.
- Read-Latches column address and transfers data from the selected sense amplifier to the output buffer as determined by the column address. During each succeeding clock edge, additional data is driven without additional read commands. The amount of data transferred is determined by the burst size.
- Write-Latches column address and transfers data from the data pins to the selected sense amplifier as determined by the column address. During each succeeding clock edge, additional data is transferred to the sense amplifiers from the data pins without

#### **Functional description**

- additional write commands. The amount of data transferred is determined by the data masks and the burst size.
- Refresh (similar to MCAS\_B before MRAS\_B)-Causes a row to be read in all logical banks (JEDEC SDRAM) as determined by the refresh row address counter. This refresh row address counter is internal to the SDRAM. After being read, the row is automatically rewritten in the memory array. All logical banks must be in a precharged state before executing a refresh. The memory controller also supports posted refreshes, where several refreshes may be executed at once, and the refresh interval may be extended.
- Mode register set (for configuration)-Allows setting of DDR SDRAM options. These options are: MCAS\_B latency, additive latency (for DDR2/DDR3), write recovery (for DDR2/DDR3), burst type, and burst length. MCAS\_B latency may be chosen as provided by the preferred SDRAM. Burst type is always sequential. This memory controller supports a burst length of 4 and 8. A burst length of 8 is supported for DDR3 memory only. For DDR2 in 32-bit bus mode, all 32-byte burst accesses from the platform are split into two 16-byte (that is, 4-beat) accesses to the SDRAMs in the memory controller. The mode register set command is performed by the DDR memory controller during system initialization. Parameters such as mode register data, MCAS\_B latency, burst length, and burst type, are set by software in DDR\_SDRAM\_MODE[SDMODE] and transferred to the SDRAM array by the DDR memory controller after DDR\_SDRAM\_CFG[MEM\_EN] is set. If DDR\_SDRAM\_CFG[BI] is set to bypass the automatic initialization, then the MODE registers can be configured through software through use of the DDR\_SDRAM\_MD\_CNTL register.
- Self refresh (for long periods of standby)-Used when the device is in standby for very long periods of time. Automatically generates internal refresh cycles to keep the data in all memory banks refreshed. Before execution of this command, the DDR controller places all logical banks in a precharged state.

Table 8-66. DDR SDRAM command table

| Operation                     | CKE<br>Prev. | CKE<br>Current | MCS<br>_B | MRAS<br>_B | MCAS<br>_B | MWE<br>_B | МВА                 | MA10 | MA     |
|-------------------------------|--------------|----------------|-----------|------------|------------|-----------|---------------------|------|--------|
| Activate                      | Н            | Н              | L         | L          | Н          | Н         | Logical bank select | Row  | Row    |
| Precharge select logical bank | Н            | Н              | L         | L          | Н          | L         | Logical bank select | L    | Х      |
| Precharge all logical banks   | Н            | Н              | L         | L          | Н          | L         | Х                   | Н    | Х      |
| Read                          | Н            | Н              | L         | Н          | L          | Н         | Logical bank select | L    | Column |
| Read with auto-<br>precharge  | Н            | Н              | L         | Н          | L          | Н         | Logical bank select | Н    | Column |
| Write                         | Н            | Н              | L         | Н          | L          | L         | Logical bank select | L    | Column |

Table 8-66. DDR SDRAM command table (continued)

| Operation                     | CKE<br>Prev. | _ | MCS<br>_B | MRAS<br>_B | MCAS<br>_B | MWE<br>_B | МВА                 | MA10   | MA              |
|-------------------------------|--------------|---|-----------|------------|------------|-----------|---------------------|--------|-----------------|
| Write with auto-<br>precharge | Н            | Н | L         | Н          | L          | L         | Logical bank select | Н      | Column          |
| Mode register set             | Н            | Н | L         | L          | L          | L         | Opcode              | Opcode | Opcode and mode |
| Auto refresh                  | Н            | Н | L         | L          | L          | Н         | Х                   | Х      | Х               |
| Self refresh                  | Н            | L | L         | L          | L          | Н         | Х                   | Х      | Х               |

## 8.5.4 DDR SDRAM interface timing

The DDR memory controller supports four- (or eight-) beat bursts to SDRAM.

For single-beat reads, the DDR memory controller performs a four- (or eight-) beat burst read, but ignores the last three (or seven) beats. Single-beat writes are performed by masking the last three (or seven) beats of the four- (or eight-) beat burst using the data mask MDM[0:3]. If ECC is disabled, writes smaller than double words are performed by appropriately activating the data mask. If ECC is enabled, the controller performs a read-modify write.

#### **NOTE**

If a second read or write is pending, reads shorter than four beats are not terminated early even if some data is irrelevant.

To accommodate available memory technologies across a wide spectrum of operating frequencies, the DDR memory controller allows the setting of the intervals defined in the following table with granularity of one memory clock cycle.

Table 8-67. DDR SDRAM interface timing intervals

| Timing intervals | Definition                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACTTOACT         | The number of clock cycles from a bank-activate command until another bank-activate command within a physical bank. This interval is listed in the AC specifications of the SDRAM as t <sub>RRD</sub> .                                                                                                                                                                       |
| ACTTOPRE         | The number of clock cycles from an activate command until a precharge command is allowed. This interval is listed in the AC specifications of the SDRAM as t <sub>RAS</sub> .                                                                                                                                                                                                 |
| ACTTORW          | The number of clock cycles from an activate command until a read or write command is allowed. This interval is listed in the AC specifications of the SDRAM as t <sub>RCD</sub> .                                                                                                                                                                                             |
| BSTOPRE          | The number of clock cycles to maintain a page open after an access. The page open duration counter is reloaded with BSTOPRE each time the page is accessed (including page hits). When the counter expires, the open page is closed with an SDRAM precharge bank command as soon as possible.                                                                                 |
| CASLAT           | Used in conjunction with additive latency to obtain the READ latency. The number of clock cycles between the registration of a READ command by the SDRAM and the availability of the first piece of output data. If a READ command is registered at clock edge $n$ , and the read latency is $m$ clocks, the data is available nominally coincident with clock edge $n + m$ . |

Table 8-67. DDR SDRAM interface timing intervals (continued)

| Timing intervals | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRETOACT         | The number of clock cycles from a precharge command until an activate or a refresh command is allowed. This interval is listed in the AC specifications of the SDRAM as t <sub>RP</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| REFINT           | Refresh interval. Represents the number of memory bus clock cycles between refresh cycles. Depending on DDR_SDRAM_CFG_2[NUM_PR], some number of rows are refreshed in each SDRAM bank during each refresh cycle. The value of REFINT depends on the specific SDRAMs used and the frequency of the interface as t <sub>RP</sub> .                                                                                                                                                                                                                                                                                                            |
| REFREC           | The number of clock cycles from the refresh command until an activate command is allowed. This can be calculated by referring to the AC specification of the SDRAM device. The AC specification indicates a maximum refresh-to-activate interval in nanoseconds.                                                                                                                                                                                                                                                                                                                                                                            |
| WR_DATA_DELAY    | Provides different options for the timing between a write command and the write data strobe. This allows write data to be sent later than the nominal time to meet the SDRAM timing requirement between the registration of a write command and the reception of a data strobe associated with the write command. The specification dictates that the data strobe may not be received earlier than 75% of a cycle, or later than 125% of a cycle, from the registration of a write command. This parameter is not defined in the SDRAM specification. It is implementation-specific, defined for the DDR memory controller in TIMING_CFG_2. |
| WRREC            | The number of clock cycles from the last beat of a write until a precharge command is allowed. This interval, write recovery time, is listed in the AC specifications of the SDRAM as $t_{WR}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| WRTORD           | Last write pair to read command. Controls the number of clock cycles from the last write data pair to the subsequent read command to the same bank as t <sub>WTR</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

The value of the above parameters (in whole clock cycles) must be set by boot code at system start-up (as described in DDR SDRAM timing configuration 0 (DDR\_TIMING\_CFG\_0), DDR SDRAM timing configuration 1 (DDR\_TIMING\_CFG\_1), DDR SDRAM timing configuration 2 (DDR\_TIMING\_CFG\_2), and DDR SDRAM timing configuration 3 (DDR\_TIMING\_CFG\_3)) and be kept in the DDR memory controller configuration register space.

The following figures show SDRAM timing for various types of accesses. System software is responsible (at reset) for optimally configuring SDRAM timing parameters. The programmable timing parameters apply to both read and write timing configuration. The configuration process must be completed and the DDR SDRAM initialized before any accesses to SDRAM are attempted.

See Figure 8-57 for a single-beat read operation, Figure 8-58 for a single-beat write operation, and Figure 8-59 for a double-word write operation. Note that all signal transitions occur on the rising edge of the memory bus clock and that single-beat read operations are identical to burst-reads. These figures assume the CLK\_ADJUST is set to 1/2 DRAM cycle, an additive latency of 0 DRAM cycles is used, and the write latency is 1 DRAM cycle.



Figure 8-57. DDR SDRAM burst read timing-ACTTORW = 3, MCAS Latency = 2



Figure 8-58. DDR SDRAM single-beat (double word) write timing-ACTTORW = 3



Figure 8-59. DDR SDRAM 4-beat burst write timing-ACTTORW = 4

## 8.5.5 DDR SDRAM registered DIMM mode

To reduce loading, registered DIMMs latch the DDR SDRAM control signals internally before using them to access the array.

Setting DDR\_SDRAM\_CFG[RD\_EN] compensates for this delay on the DIMMs' control bus by delaying the data and data mask writes (on SDRAM buses) by an extra SDRAM clock cycle.

#### NOTE

Application system board must assert the reset signal on DDR memory devices until software is able to program the DDR memory controller configuration registers, and must deassert the reset signal on DDR memory devices before DDR\_SDRAM\_CFG[MEM\_EN] is set. This ensures that the DDR memory devices are held in reset until a stable clock is provided and, further, that a stable clock is provided before memory devices are released from reset.

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

The figure below shows the registered DDR SDRAM DIMM burst write timing.



Figure 8-60. Registered DDR SDRAM DIMM burst write timing

#### 8.5.6 DDR SDRAM write timing adjustments

The DDR memory controller facilitates system design flexibility by providing a write timing adjustment parameter, write data delay, (TIMING\_CFG\_2[WR\_DATA\_DELAY]) for data and DQS.

The DDR SDRAM specification requires DQS be received no sooner than 75% of an SDRAM clock period-and no later than 125% of a clock period-from the capturing clock edge of the command/address at the SDRAM. The WR\_DATA\_DELAY parameter may be used to meet this timing requirement for a variety of system configurations, ranging from a system with one DIMM to a fully populated system with two DIMMs.

TIMING\_CFG\_2[WR\_DATA\_DELAY] specifies how much to delay the launching of DQS and data from the first clock edge occurring. The delay increment step sizes are in 1/4 SDRAM clock periods starting with the default value of 0.

The figure below shows the use of the WR\_DATA\_DELAY parameter.



Figure 8-61. Write timing adjustments example for write latency = 1

#### 8.5.7 DDR SDRAM refresh

The DDR memory controller supports auto-refresh and self-refresh.

Auto-refresh is used during normal operation and is controlled by the DDR\_SDRAM\_INTERVAL[REFINT] value; self-refresh is used only when the DDR memory controller is set to enter a sleep power management state. The REFINT value, which represents the number of memory bus clock cycles between refresh cycles, must allow for possible outstanding transactions to complete before a refresh request is sent to the memory after the REFINT value is reached. If a memory transaction is in progress when the refresh interval is reached, the refresh cycle waits for the transaction to complete. In the worst case, the refresh cycle must wait the number of bus clock cycles required by the longest programmed access. To ensure that the latency caused by a memory transaction does not violate the device refresh period, it is recommended that the programmed value of REFINT be less than that required by the SDRAM.

When a refresh cycle is required, the DDR memory controller does the following:

1. Completes all current memory requests.

- 2. Closes all open pages with a PRECHARGE-ALL command to each DDR SDRAM bank with an open page (as indicated by the row open table).
- 3. Issues one or more auto-refresh commands to each DDR SDRAM bank (as identified by its chip select) to refresh one row in each logical bank of the selected physical bank.

The auto-refresh commands are staggered across the two possible banks to reduce the system's instantaneous power requirements. Three sets of auto refresh commands are issued on consecutive cycles when the memory is populated with one DIMMs. The initial PRECHARGE-ALL commands are also staggered in three groups for convenience. It is important to note that when entering self-refresh mode, only one refresh command is issued simultaneously to all physical banks. For this entire refresh sequence, no cycle optimization occurs for the usual case where fewer than two banks are installed. After the refresh sequence completes, any pending memory request is initiated after an inactive period specified by TIMING\_CFG\_1 [REFREC] and TIMING\_CFG\_3[EXT\_REFREC]. In addition, posted refreshes are supported to allow the refresh interval to be set to a larger value.

#### 8.5.7.1 DDR SDRAM refresh timing

Refresh timing for the DDR SDRAM is controlled by the programmable timing parameter TIMING\_CFG\_1 [REFREC], which specifies the number of memory bus clock cycles from the refresh command until a logical bank activate command is allowed.

The DDR memory controller implements bank staggering for refreshes, as shown in the figure below (TIMING\_CFG\_1 [REFREC] = 10 in this example).



Figure 8-62. DDR SDRAM bank staggered auto refresh timing

#### **Functional description**

System software is responsible for optimal configuration of TIMING\_CFG\_1 [REFREC] and TIMING\_CFG\_3[EXT\_REFREC] at reset. Configuration must be completed before DDR SDRAM accesses are attempted.

#### 8.5.7.2 DDR SDRAM refresh and power-saving modes

In full-on mode, the DDR memory controller supplies the normal auto refresh to SDRAM.

In sleep mode, the DDR memory controller can be configured to take advantage of self-refreshing SDRAMs or to provide no refresh support. Self-refresh support is enabled with the SREN memory control parameter.

The table below summarizes the refresh types available in each power-saving mode.

Table 8-68. DDR SDRAM power-saving modes refresh configuration

| Power saving mode | Refresh type | SREN |
|-------------------|--------------|------|
| Sleep             | Self         | 1    |
|                   | None         | -    |

Note that in the absence of refresh support, system software must preserve DDR SDRAM data (such as by copying the data to disk) before entering the power-saving mode.

The dynamic power-saving mode uses the CKE DDR SDRAM pin to dynamically power down when there is no system memory activity. The CKE pin is negated when both of the following conditions are met:

- No memory refreshes are scheduled
- No memory accesses are scheduled

CKE is reasserted when a new access or refresh is scheduled or the dynamic power mode is disabled. This mode is controlled with DDR\_SDRAM\_CFG[DYN\_PWR\_MGMT].

Dynamic power management mode offers tight control of the memory system's power consumption by trading power for performance through the use of CKE. Powering up the DDR SDRAM when a new memory reference is scheduled causes an access latency penalty, depending on whether active or precharge powerdown is used, along with the settings of TIMING\_CFG\_0[ACT\_PD\_EXIT] and TIMING\_CFG\_0[PRE\_PD\_EXIT]. For example, a penalty of 1 cycle is shown in the following figure.



Figure 8-63. DDR SDRAM power-down mode

#### 8.5.7.2.1 Self-refresh in sleep mode

The entry and exit timing for self-refreshing SDRAMs is shown in the following figures.



Figure 8-64. DDR SDRAM self-refresh entry timing



Figure 8-65. DDR2 SDRAM self-refresh exit timing



Figure 8-66. DDR3 SDRAM self-refresh exit timing

#### **NOTE**

Deep sleep mode is not supported for DDR3 registered DIMMS.

#### 8.5.8 DDR data beat ordering

Transfers to and from memory are always performed in four- or eight-beat bursts.

For transfer sizes other than four or eight beats, the data transfers are still operated as four- or eight-beat bursts. If ECC is enabled and either the access is not double-word aligned or the size is not a multiple of a double word, a full read-modify-write is performed for a write to SDRAM. If ECC is disabled or both the access is double-word aligned with a size that is a multiple of a double word, the data masks MDM[0:3] and MDM[8] The DDR memory controller also uses data masks to prevent all unintended full double words from writing to SDRAM. For example, if a write transaction is desired with a size of one double word (8 bytes), then the second, third, and fourth beats of data are not written to DRAM, as the width of the data bus is 64 bits.

The table below lists the data beat sequencing to and from the DDR SDRAM and the data queues for each of the possible transfer sizes with each of the possible starting doubleword offsets. All underlined double-word offsets are valid for the transaction.

| Transfer Size  | Starting double-word offset | Double-word sequence <sup>1</sup> to/from DRAM and queues |
|----------------|-----------------------------|-----------------------------------------------------------|
| 1 double word  | 0                           | <u>0</u> - 1 - 2 - 3                                      |
|                | 1                           | <u>1</u> - 2 - 3 - 0                                      |
|                | 2                           | <u>2</u> - 3 - 0 - 1                                      |
|                | 3                           | <u>3</u> - 0 - 1 - 2                                      |
| 2 double words | 0                           | <u>0 - 1</u> - 2 - 3                                      |
|                | 1                           | <u>1 - 2</u> - 3 - 0                                      |
|                | 2                           | <u>2 - 3</u> - 0 - 1                                      |
| 3 double words | 0                           | <u>0 - 1 - 2</u> - 3                                      |
|                | 1                           | <u>1 - 2 - 3</u> - 0                                      |

Table 8-69. Memory controller-data beat ordering

#### 8.5.9 Page mode and logical bank retention

The DDR memory controller supports an open/closed page mode with an allowable open page for each logical bank of DRAM used.

In closed page mode for DDR SDRAMs, the DDR memory controller uses the SDRAM auto-precharge feature, which allows the controller to indicate that the page must be automatically closed by the DDR SDRAM after the READ or WRITE access. This is performed using MA[10] of the address during the COMMAND phase of the access to

<sup>1.</sup> All underlined double-word offsets are valid for the transaction. All writes are aligned to double-word 0 for DDR3 memories.

#### **Functional description**

enable auto-precharge. Auto-precharge is non-persistent in that it is either enabled or disabled for each individual READ or WRITE command. It can, however, be enabled or disabled separately for each chip select.

When the DDR memory controller operates in open page mode, it retains the currently active SDRAM page by not issuing a precharge command. The page remains open until one of the following conditions occurs:

- Refresh interval is met.
- The user-programmable DDR\_SDRAM\_INTERVAL[BSTOPRE] value is exceeded.
- There is a logical bank row collision with another transaction that must be issued.

Page mode can dramatically reduce access latencies for page hits. Depending on the memory system design and timing parameters, using page mode can save two to three clock cycles for subsequent burst accesses that hit in an active page. Also, better performance can be obtained using more banks, especially in systems which use many different channels. Page mode is disabled by clearing

DDR\_SDRAM\_INTERVAL[BSTOPRE] or setting CSn\_CONFIG[AP\_nEN].

## 8.5.10 Error checking and correcting (ECC)

The DDR memory controller supports error checking and correcting (ECC) for the data path between the core master and system memory.

The memory detects all double-bit errors, detects all multi-bit errors within a nibble, and corrects all single-bit errors. Other errors may be detected, but are not guaranteed to be corrected or detected. Multi-bit errors are always reported when error reporting is enabled. When a single-bit error occurs, the single-bit error counter register is incremented, and its value compared to the single-bit error trigger register. An error is reported when these values are equal. The single-bit error registers can be programmed such that minor memory faults are corrected and ignored, but a catastrophic memory failure generates an interrupt.

For writes that are smaller than 32 bits, the DDR memory controller performs a double-word read from system memory of the address for the write (checking for errors), and merges the write data with the data read from memory. Then, a new ECC code is generated for the merged double word. The data and ECC code is then written to memory. If a multi-bit error is detected on the read, the transaction completes the read-modify-write to keep the DDR memory controller from hanging. However, the corrupt data is masked on the write, so the original contents in SDRAM remain unchanged.

The syndrome encodings for the ECC code are shown in the following table.

Table 8-70. DDR SDRAM ECC syndrome encoding (check bits)

| Check bit |   |   |   | Syndr | ome bit |   |   |   |
|-----------|---|---|---|-------|---------|---|---|---|
|           | 0 | 1 | 2 | 3     | 4       | 5 | 6 | 7 |
| 0         | • |   |   |       |         |   |   |   |
| 1         |   | • |   |       |         |   |   |   |
| 2         |   |   | • |       |         |   |   |   |
| 3         |   |   |   | •     |         |   |   |   |
| 4         |   |   |   |       | •       |   |   |   |
| 5         |   |   |   |       |         | • |   |   |
| 6         |   |   |   |       |         |   | • |   |
| 7         |   |   |   |       |         |   |   | • |

#### 8.5.11 Error management

The DDR memory controller detects four different kinds of errors: training, single-bit, multi-bit, and memory select errors.

The following discussion assumes all the relevant error detection, correction, and reporting functions are enabled as described in Memory error interrupt enable (DDR\_ERR\_INT\_EN), Memory error disable (DDR\_ERR\_DISABLE), and Memory error detect (DDR\_ERR\_DETECT).

Single-bit errors are counted and reported based on the ERR\_SBE value. When a single-bit error is detected, the DDR memory controller does the following:

- Corrects the data
- Increments the single-bit error counter ERR\_SBE[SBEC]
- Generates an interrupt if the counter value ERR\_SBE[SBEC] equals the programmable threshold ERR\_SBE[SBET]
- Completes the transaction normally

If a multi-bit error is detected for a read, the DDR memory controller logs the error and generates the interrupt. Another error the DDR memory controller detects is a memory select error, which causes the DDR memory controller to log the error and generate an interrupt (if enabled, as described in Memory error detect (DDR\_ERR\_DETECT)). This error is detected if the address from the memory request does not fall into any of the enabled, programmed chip select address ranges. For all memory select errors, the DDR memory controller does not issue any transactions onto the pins after the first read has returned data strobes. If the DDR memory controller is not using sample points, then a dummy transaction is issued to DDR SDRAM with the first enabled chip select. In this case, the source port on the pins is forced to 0x1F to show the transaction is not real. The

#### Initialization/application information

table below shows the errors with their descriptions. The final error the memory controller detects is the automatic calibration error. This error is set if the memory controller detects an error during its training sequence.

Table 8-71. Memory controller errors

| Category     | Error                                                                                                                                                                         | Descriptions                                                                            | Action                                                               | Detect Register                      |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------|
| Notification | Single-bit ECC threshold                                                                                                                                                      | The number of ECC errors has reached the threshold specified in the ERR_SBE.            | Regular or critical interrupt (if enabled)                           | The error control register only logs |
| Access Error | Multi-bit ECC error                                                                                                                                                           | A multi-bit ECC error is detected during a read, or read-modify-write memory operation. | Machine check for e500 core initiated read versus with not full type |                                      |
|              | Memory select error Read, or write, address does not fall within the address range of any of the memory banks. reads (if enabled), or regular/critical interrupt (if enabled) |                                                                                         |                                                                      |                                      |

## 8.6 Initialization/application information

System software must configure the DDR memory controller, using a memory polling algorithm at system start-up, to correctly map the size of each bank in memory.

Then, the DDR memory controller uses its bank map to assert the appropriate  $\overline{\text{MCSn}}$  signal for memory accesses according to the provided bank depths. System software must also configure the DDR memory controller at system start-up to appropriately multiplex the row and column address bits for each bank. Refer to row-address configuration in Chip select n configuration (DDR\_CSn\_CONFIG). Address multiplexing occurs according to these configuration bits.

At system reset, initialization software (boot code) must set up the programmable parameters in the memory interface configuration registers. See DDR memory map/register definition for more detailed descriptions of the configuration registers. These parameters are shown in the following table.

Table 8-72. Memory interface configuration register initialization parameters

| Name     | Description               | Parameter | Section/<br>page                                        |
|----------|---------------------------|-----------|---------------------------------------------------------|
| CSn_BNDS | Chip select memory bounds | EAn       | Chip select n<br>memory<br>bounds<br>(DDR_CSn_B<br>NDS) |

Table 8-72. Memory interface configuration register initialization parameters (continued)

| Name          | Description                    | Par          | ameter        | Section/<br>page                                              |
|---------------|--------------------------------|--------------|---------------|---------------------------------------------------------------|
| CSn_CONFIG    | Chip select configuration      | CS_n_EN      | BA_BITS_CS_n  | Chip select n                                                 |
|               |                                | AP_n_EN      | ROW_BITS_CS_n | configuration (DDR_CSn_C                                      |
|               |                                | ODT_RD_CFG   | COL_BITS_CS_n | ONFIG)                                                        |
|               |                                | ODT_WR_CFG   |               |                                                               |
| CSn_CONFIG_2  | Chip select configuration 2    | PASR_CFG     |               | Chip select n<br>configuration<br>2<br>(DDR_CSn_C<br>ONFIG_2) |
| TIMING_CFG_3  | Extended timing parameters for | EXT_REFREC   |               | DDR SDRAM                                                     |
|               | fields in TIMING_CFG_1         | EXT_ACTTOPRE |               | timing configuration                                          |
|               |                                | EXT_CASLAT   |               | 3                                                             |
|               |                                | CNTL_ADJ     |               | (DDR_TIMIN<br>G_CFG_3)                                        |
| TIMING_CFG_0  | Timing configuration           | RWT          | ACT_PD_EXIT   | DDR SDRAM                                                     |
|               |                                | WRT          | PRE_PD_EXIT   | timing configuration                                          |
|               |                                | RRT          | ODT_PD_EXIT   | 0                                                             |
|               |                                | WWT          | MRS_CYC       | (DDR_TIMIN G_CFG_0)                                           |
| TIMING_CFG_1  | Timing configuration           | PRETOACT     | REFREC        | DDR SDRAM                                                     |
|               |                                | ACTTOPRE     | WRREC         | timing configuration                                          |
|               |                                | ACTTORW      | ACTTOACT      | 1                                                             |
|               |                                | CASLAT       | WRTORD        | (DDR_TIMIN<br>G_CFG_1)                                        |
| TIMING_CFG_2  | Timing configuration           | ADD_LAT      | WR_DATA_DELAY | DDR SDRAM                                                     |
|               |                                | СРО          | CKE_PLS       | timing configuration                                          |
|               |                                | WR_LAT       | FOUR_ACT      | 2                                                             |
|               |                                | RD_TO_PRE    |               | (DDR_TIMIN<br>G_CFG_2)                                        |
| DDR_SDRAM_CFG | Control configuration          | SREN         | 2T_EN         | DDR SDRAM                                                     |
|               |                                | ECC_EN       | 3T_EN         | control configuration                                         |
|               |                                | RD_EN        | BA_INTLV_CTL  | (DDR_DDR_                                                     |
|               |                                | SDRAM_TYPE   | x32_EN        | SDRAM_CFG                                                     |
|               |                                | DYN_PWR      | HSE           | ,                                                             |
|               |                                | 8_BE         | BI            |                                                               |
|               |                                | DBW          | MEM_EN        |                                                               |
|               |                                | MEM_HALT     | PCHB8         |                                                               |

Table 8-72. Memory interface configuration register initialization parameters (continued)

| Name               | Description                                | Pa                                       | arameter                         | Section/<br>page                                                    |
|--------------------|--------------------------------------------|------------------------------------------|----------------------------------|---------------------------------------------------------------------|
| DDR_SDRAM_CFG_2    | Control configuration                      | SR_IE DLL_RST_DIS DQS_CFG ODT_CFG FRC_SR | NUM_PR AP_EN D_INIT RCW_EN MD_EN | DDR SDRAM control configuration 2 (DDR_DDR_ SDRAM_CFG _2)           |
| DDR_SDRAM_MODE     | Mode configuration                         | ESDMODE<br>SDMODE                        |                                  | DDR SDRAM mode configuration (DDR_DDR_ SDRAM_MO DE)                 |
| DDR_SDRAM_MODE_2   | Mode configuration                         | ESDMODE2<br>ESDMODE3                     |                                  | DDR SDRAM mode configuration 2 (DDR_DDR_ SDRAM_MO DE_2)             |
| DDR_SDRAM_INTERVAL | Interval configuration                     | REFINT<br>BSTOPRE                        |                                  | DDR SDRAM interval configuration (DDR_DDR_ SDRAM_INT ERVAL)         |
| DDR_DATA_INIT      | Data initialization configuration register | INIT_VALUE                               |                                  | DDR SDRAM data initialization (DDR_DDR_DATA_INIT)                   |
| DDR_SDRAM_CLK_CNTL | Clock adjust                               | CLK_ADJUST                               |                                  | DDR SDRAM<br>clock control<br>(DDR_DDR_<br>SDRAM_CLK<br>_CNTL)      |
| DDR_INIT_ADDR      | Initialization address                     | INIT_ADDR                                |                                  | DDR training initialization address (DDR_DDR_I NIT_ADDR)            |
| TIMING_CFG_4       | Timing configuration                       | RWT WRT RRT WWT DLL_LOCK                 |                                  | DDR SDRAM<br>timing<br>configuration<br>4<br>(DDR_TIMIN<br>G_CFG_4) |

Table 8-72. Memory interface configuration register initialization parameters (continued)

| Name             | Description                          | Parameter     | Section/<br>page                                        |
|------------------|--------------------------------------|---------------|---------------------------------------------------------|
| TIMING_CFG_5     | Timing configuration                 | RODT_ON       | DDR SDRAM                                               |
|                  |                                      | RODT_OFF      | timing configuration                                    |
|                  |                                      | WODT_ON       | 5                                                       |
|                  |                                      | WODT_OFF      | (DDR_TIMIN<br>G_CFG_5)                                  |
| DDR_ZQ_CNTL      | ZQ calibration control               | ZQ_EN         | DDR ZQ                                                  |
|                  |                                      | ZQINIT        | calibration                                             |
|                  |                                      | ZQOPER        | (DDR_DDR_                                               |
|                  |                                      | ZQCS          | ZQ_CNTL)                                                |
| DDR_WRLVL_CNTL   | Write leveling control               | WRLVL_EN      | DDR write                                               |
|                  |                                      | WRLVL_MRD     | leveling control                                        |
|                  |                                      | WRLVL_ODTEN   | (DDR_DDR_                                               |
|                  |                                      | WRLVL_DQSEN   | WRLVL_CNT<br>L)                                         |
|                  |                                      | WRLVL_SMPL    |                                                         |
|                  |                                      | WRLVL_WLR     |                                                         |
|                  |                                      | WRLVL_START   |                                                         |
| DDR_WRLVL_CNTL_2 | Write leveling control               | WRLVL_START_1 | DDR write                                               |
|                  |                                      | WRLVL_START_2 | leveling control 2                                      |
|                  |                                      | WRLVL_START_3 | (DDR_DDR_                                               |
|                  |                                      | WRLVL_START_4 | WRLVL_CNT<br>L_2)                                       |
| DDR_WRLVL_CNTL_3 | Write leveling control               | WRLVL_START_5 | DDR write                                               |
|                  |                                      | WRLVL_START_6 | leveling control 3                                      |
|                  |                                      | WRLVL_START_7 | (DDR_DDR_                                               |
|                  |                                      | WRLVL_START_8 | WRLVL_CNT<br>L_3)                                       |
| DDR_SR_CNTR      | Self refresh control                 | SR_IT         | DDR Self<br>Refresh<br>Counter<br>(DDR_DDR_<br>SR_CNTR) |
| DDR_SDRAM_RCW_1  | Register control words configuration | RCW0          | DDR Register                                            |
|                  |                                      | RCW1          | Control<br>Words 1                                      |
|                  |                                      | RCW2          | (DDR_DDR_                                               |
|                  |                                      | RCW3          | SDRAM_RC<br>W_1)                                        |
|                  |                                      | RCW4          | "-"/                                                    |
|                  |                                      | RCW5          |                                                         |
|                  |                                      | RCW6          |                                                         |
|                  |                                      | RCW7          |                                                         |

Table 8-72. Memory interface configuration register initialization parameters (continued)

| Name              | Name Description                     |               | ımeter  | Section/<br>page                                                         |
|-------------------|--------------------------------------|---------------|---------|--------------------------------------------------------------------------|
| DDR_SDRAM_RCW_2   | Register control words configuration | RCW8          |         | DDR Register                                                             |
|                   |                                      | RCW9          |         | Control<br>Words 2                                                       |
|                   |                                      | RCW10         |         | (DDR_DDR_                                                                |
|                   |                                      | RCW11         |         | SDRAM_RC W_2)                                                            |
|                   |                                      | RCW12         |         | _ /                                                                      |
|                   |                                      | RCW13         |         |                                                                          |
|                   |                                      | RCW14         |         |                                                                          |
|                   |                                      | RCW15         |         |                                                                          |
| DDRCDR_1          | Driver control                       | DHC_EN        | DSO_CPZ | DDR Control                                                              |
|                   |                                      | ODT           | DSO_CNZ | Driver<br>Register 1                                                     |
|                   |                                      | DSO_C_EN      | DSO_DPZ | (DDR_DDRC                                                                |
|                   |                                      | DSO_D_EN      | DSO_DNZ | DR_1)                                                                    |
| DDRCDR_2          | Driver control                       | DSO_CLK_EN    |         | DDR Control                                                              |
|                   |                                      | DSO_CLKPZ     |         | Driver<br>Register 2                                                     |
|                   |                                      | DSO_CLKNZ     |         | (DDR_DDRC                                                                |
|                   |                                      | ODT           |         | DR_2)                                                                    |
| DDR_INIT_EXT_ADDR | Extended initialization address      | UIA           |         | DDR training                                                             |
|                   |                                      | INIT_EXT_ADDR |         | initialization<br>extended<br>address<br>(DDR_DDR_I<br>NIT_EXT_AD<br>DR) |

## 8.6.1 Programming differences between memory types

Depending on the memory type used, certain fields must be programmed differently.

The table below illustrates the differences in certain fields for different memory types. Note that this table does not list all fields that must be programmed.

Table 8-73. Programming differences between memory types

| Parameter | Description        | Differences                                               |
|-----------|--------------------|-----------------------------------------------------------|
| APn_EN    | Chip Select n Auto | DDR2/DDR3                                                 |
|           | precharge enable   | Can be used to place chip select n in auto precharge mode |
|           |                    | See also: Chip select n configuration (DDR_CSn_CONFIG)    |

Table 8-73. Programming differences between memory types (continued)

| Parameter   | Description                | Differences                                                                                                                                                                                                              |
|-------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ODT_RD_CFG  | Chip Select ODT read       | DDR2/DDR3                                                                                                                                                                                                                |
|             | configuration              | Can be enabled to assert ODT if desired. This could be set differently depending on system topology. However, systems with only 1 chip select will typically not use ODT when issuing reads to the memory.               |
|             |                            | See also: Chip select n configuration (DDR_CSn_CONFIG)                                                                                                                                                                   |
| ODT_WR_CFG  | Chip Select ODT write      | DDR2/DDR3                                                                                                                                                                                                                |
|             | configuration              | Can be enabled to assert ODT if desired. This could be set differently depending on system topology. However, ODT is typically set to assert for the chip select that is getting written to (value would be set to 001). |
|             |                            | See also: Chip select n configuration (DDR_CSn_CONFIG)                                                                                                                                                                   |
| ODT_PD_EXIT | ODT powerdown exit         | DDR2                                                                                                                                                                                                                     |
|             |                            | Should be set according to the DDR2 specifications for the memory used. The JEDEC parameter this applies to is $t_{\rm AXPD}$ .                                                                                          |
|             |                            | DDR3                                                                                                                                                                                                                     |
|             |                            | Should be set to 0001 for DDR3. The powerdown times (t <sub>XP</sub> and t <sub>XPDLL</sub> ) required for DDR3 are controlled via TIMING_CFG_0[ACT_PD_EXIT] and TIMING_CFG_0[PRE_PD_EXIT].                              |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
| PRETOACT    | OACT Precharge to activate | DDR2/DDR3                                                                                                                                                                                                                |
| tiı         | timing                     | Should be set according to the specifications for the memory used (t <sub>RP</sub> )                                                                                                                                     |
|             |                            | See also: DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)                                                                                                                                                            |
| ACTTOPRE    | Activate to precharge      | DDR2/DDR3                                                                                                                                                                                                                |
|             | timing                     | Should be set, along with the Extended Activate to Precharge Timing, according to the specifications for the memory used (t <sub>RAS</sub> )                                                                             |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
| ACTTORW     | Activate to read/write     | DDR2/DDR3                                                                                                                                                                                                                |
|             | timing                     | Should be set according to the specifications for the memory used (t <sub>RCD</sub> )                                                                                                                                    |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
| CASLAT      | CAS latency                | DDR2/DDR3                                                                                                                                                                                                                |
|             |                            | Should be set, along with the Extended CAS Latency, to the desired CAS latency                                                                                                                                           |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
| REFREC      | Refresh recovery           | DDR2/DDR3                                                                                                                                                                                                                |
|             |                            | Should be set, along with the Extended Refresh Recovery, to the specifications for the memory used $(T_{\rm RFC})$                                                                                                       |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
| WRREC       | Write Recovery             | DDR2                                                                                                                                                                                                                     |
|             |                            | Should be set according to the specifications for the memory used (twR)                                                                                                                                                  |
|             |                            | DDR3                                                                                                                                                                                                                     |
|             |                            | Should be set according to the specifications for the memory used (twR).                                                                                                                                                 |
|             |                            | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                                            |
|             |                            | <u> </u>                                                                                                                                                                                                                 |

Table 8-73. Programming differences between memory types (continued)

| Parameter | Description              | Differences                                                                                                                                                                                          |
|-----------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACTTOACT  | Activate A to Activate B | DDR2/DDR3                                                                                                                                                                                            |
|           |                          | Should be set according to the specifications for the memory used (t <sub>RRD</sub> )                                                                                                                |
|           |                          | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                        |
| WRTORD    | Write to read timing     | DDR2                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used (t <sub>WTR</sub> )                                                                                                                |
|           |                          | DDR3                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used (t <sub>WTR</sub> )                                                                                                                |
|           |                          | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                        |
| ADD_LAT   | Additive latency         | DDR2/DDR3                                                                                                                                                                                            |
|           |                          | Should be set to the desired additive latency. This must be set to a value less than TIMING_CFG_1[ACTTORW]                                                                                           |
|           |                          | See also: DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)                                                                                                                                        |
| WR_LAT    | Write latency            | DDR2                                                                                                                                                                                                 |
|           |                          | Should be set to CAS latency - 1 cycle. For example, if the CAS latency if 5 cycles, then this field should be set to 100 (4 cycles).                                                                |
|           |                          | DDR3                                                                                                                                                                                                 |
|           |                          | Should be set to the desired write latency. Note that DDR3 SDRAMs do not necessarily require the write latency to equal the CAS latency minus 1 cycle.                                               |
|           |                          | See also: DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)                                                                                                                                        |
| RD_TO_PRE | Read to precharge timing | DDR2                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used ( $t_{RTP}$ ). Time between read and precharge for non-zero value of additive latency (AL) is a minimum of AL + $t_{RTP}$ cycles.  |
|           |                          | DDR3                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used $(t_{RTP})$ . Time between read and precharge for non-zero value of additive latency $(AL)$ is a minimum of $AL + t_{RTP}$ cycles. |
|           |                          | See also: DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)                                                                                                                                        |
| CKE_PLS   | Minimum CKE pulse        | DDR2/DDR3                                                                                                                                                                                            |
|           | width                    | Should be set according to the specifications for the memory used (t <sub>CKE</sub> )                                                                                                                |
|           |                          | See also: DDR SDRAM timing configuration 1 (DDR_TIMING_CFG_1)                                                                                                                                        |
| FOUR_ACT  | Four activate window     | DDR2                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used (t <sub>FAW</sub> ). Only applies to eight logical banks.                                                                          |
|           |                          | DDR3                                                                                                                                                                                                 |
|           |                          | Should be set according to the specifications for the memory used $(t_{\text{FAW}})$ .                                                                                                               |
|           |                          | See also: DDR SDRAM timing configuration 0 (DDR_TIMING_CFG_0)                                                                                                                                        |

Table 8-73. Programming differences between memory types (continued)

| Parameter   | Description            | Differences                                                                                                                                                                         |
|-------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RD_EN       | Registered DIMM enable | DDR2/DDR3                                                                                                                                                                           |
|             |                        | If registered DIMMs are used, then this field should be set to 1                                                                                                                    |
|             |                        | See also: DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG)                                                                                                                       |
| 8_BE        | 8-beat burst enable    | DDR2                                                                                                                                                                                |
|             |                        | Should be set to 0                                                                                                                                                                  |
|             |                        | DDR3                                                                                                                                                                                |
|             |                        | For 32-bit, this may be set to 1 . If this is set to 0, then other requirements in TIMING_CFG_4 are needed to ensure t <sub>CCD</sub> is met.                                       |
|             |                        | See also: DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG)                                                                                                                       |
| 2T_EN       | 2T timing enable       | DDR2/DDR3                                                                                                                                                                           |
|             |                        | In heavily loaded systems, this can be set to 1 to gain extra timing margin on the interface at the cost of address/command bandwidth.                                              |
|             |                        | See also: DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG)                                                                                                                       |
| DLL_RST_DIS | DLL reset disable      | DDR2                                                                                                                                                                                |
|             |                        | Should typically be set to 0, unless it is desired to bypass the DLL reset when exiting self refresh.                                                                               |
|             |                        | DDR3                                                                                                                                                                                |
|             |                        | Should be set to 1                                                                                                                                                                  |
|             |                        | See also: DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2)                                                                                                                   |
| DQS_CFG     | DQS configuration      | DDR2                                                                                                                                                                                |
|             |                        | Should be set to 01                                                                                                                                                                 |
|             |                        | DDR3                                                                                                                                                                                |
|             |                        | Should be set to 01                                                                                                                                                                 |
|             |                        | See also: DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2)                                                                                                                   |
| ODT_CFG     | ODT configuration      | DDR2/DDR3                                                                                                                                                                           |
|             |                        | Can be set for termination at the IOs according to system topology. Typically, if ODT is enabled, then the internal IOs should be set up for termination only during reads to DRAM. |
|             |                        | See also: DDR SDRAM control configuration 2 (DDR_DDR_SDRAM_CFG_2)                                                                                                                   |

Table 8-73. Programming differences between memory types (continued)

| Parameter | Description                                                    | Differences                                                                                                                                                                                                                                                               |
|-----------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RWT       | Read-to-write turnaround                                       | DDR2                                                                                                                                                                                                                                                                      |
|           | for same chip select (in TIMING_CFG_4)                         | Should typically be set to 0000                                                                                                                                                                                                                                           |
|           |                                                                | DDR3                                                                                                                                                                                                                                                                      |
|           |                                                                | This can be used to force a longer read-to-write turnaround time when accessing the same chip select. This is useful for burst chop mode, as there are some timing requirements to the same chip select that still must be met.                                           |
|           |                                                                | See also: DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                                                                                                                                                                                                             |
| WRT       | Write-to-read turnaround                                       | DDR2                                                                                                                                                                                                                                                                      |
|           | for same chip select (in TIMING_CFG_4)                         | Should typically be set to 0000                                                                                                                                                                                                                                           |
|           |                                                                | DDR3                                                                                                                                                                                                                                                                      |
|           |                                                                | This could be used to force a certain turnaround time between a write and read to the same chip select. This is useful for burst chop mode. However, it is expected that TIMING_CFG_1[WRTORD] is programmed appropriately such that TIMING_CFG_4[WRT] can be set to 0000. |
|           |                                                                | See also: DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                                                                                                                                                                                                             |
| RRT F     | Read-to-read turnaround for same chip select (in TIMING_CFG_4) | DDR2                                                                                                                                                                                                                                                                      |
|           |                                                                | Should typically be set to 0000                                                                                                                                                                                                                                           |
|           | TIWIING_OF G_+/                                                | DDR3                                                                                                                                                                                                                                                                      |
|           |                                                                | Should typically be set to 0010 in burst chop mode (on-the-fly or fixed) or set to 0000 in fixed 8-beat burst mode.                                                                                                                                                       |
|           |                                                                | See also: DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                                                                                                                                                                                                             |
| WWT       | Write-to-write turnaround                                      | DDR2                                                                                                                                                                                                                                                                      |
|           | for same chip select (in TIMING_CFG_4)                         | Should typically be set to 0000                                                                                                                                                                                                                                           |
|           |                                                                | DDR3                                                                                                                                                                                                                                                                      |
|           |                                                                | Should typically be set to 0010 in burst chop mode (on-the-fly or fixed) or set to 0000 in fixed 8-beat burst mode.                                                                                                                                                       |
|           |                                                                | See also: DDR SDRAM timing configuration 4 (DDR_TIMING_CFG_4)                                                                                                                                                                                                             |
| ZQ_EN     | ZQ Calibration enable                                          | DDR2                                                                                                                                                                                                                                                                      |
|           |                                                                | Should be set to 0                                                                                                                                                                                                                                                        |
|           |                                                                | DDR3                                                                                                                                                                                                                                                                      |
|           |                                                                | Should be set to 1. The other fields in DDR_ZQ_CNTL should also be programmed appropriately based on the DRAM specifications.                                                                                                                                             |
|           |                                                                | See also: DDR ZQ calibration control (DDR_DDR_ZQ_CNTL)                                                                                                                                                                                                                    |

Table 8-73. Programming differences between memory types (continued)

| Parameter | Description           | Differences                                                                                                                                                                                                                                                                                |
|-----------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WRLVL_EN  | Write leveling enable | DDR2                                                                                                                                                                                                                                                                                       |
|           |                       | Should be set to 0                                                                                                                                                                                                                                                                         |
|           |                       | DDR3                                                                                                                                                                                                                                                                                       |
|           |                       | Can be set to 1 if write leveling is desired. Otherwise the value used in TIMING_CFG_2[WR_DATA_DELAY] is used to shift all bytes during writes to DRAM. If write leveling is used, all other fields in DDR_WRLVL_CNTL should be programmed appropriately based on the DRAM specifications. |
|           |                       | See also: DDR write leveling control (DDR_DDR_WRLVL_CNTL)                                                                                                                                                                                                                                  |
| BSTOPR    | Burst To precharge    | DDR2/DDR3                                                                                                                                                                                                                                                                                  |
|           | interval              | Can be set to any value, depending on the application. Auto precharge can be enabled by setting this field to all 0s.                                                                                                                                                                      |
|           |                       | See also: DDR SDRAM interval configuration (DDR_DDR_SDRAM_INTERVAL)                                                                                                                                                                                                                        |

### 8.6.2 DDR SDRAM initialization sequence

After configuration of all parameters is complete, system software must set DDR\_SDRAM\_CFG[MEM\_EN] to enable the memory interface.

Note that 200 µs (500 µs for DDR3) must elapse after DRAM clocks are stable (DDR\_SDRAM\_CLK\_CNTL[CLK\_ADJUST] is set and any chip select is enabled) before MEM\_EN can be set, so a delay loop in the initialization code may be necessary if software is enabling the memory controller. If DDR\_SDRAM\_CFG[BI] is not set, the DDR memory controller conducts an automatic initialization sequence to the memory, which follows the memory specifications. If the bypass initialization mode is used, then software can initialize the memory through the DDR\_SDRAM\_MD\_CNTL register.

## 8.7 Using Forced Self-Refresh Mode to Implement a Battery-Backed RAM System

This section describes the options offered by this device to support battery-backed main memory.

The MRS commands to the DRAM are bypassed that is supported through DDR\_SDRAM\_CFG[BI]. The other training and calibrations run at POR still runs by the DDRC.

#### 8.7.1 Hardware Based Self-Refresh Scheme

An external voltage sense device can be connected to this device through one of the external interrupt lines IRQn. The external interrupt from the voltage sensor would then be steered through the programmable interrupt controller (PIC) to the internal SoC interrupt event signal, sie0. Note that the sie0 signal must remain high until power is removed. Also note that sie0 is sent to both DDR controllers at the same time.

If DDR\_SDRAM\_CFG\_2[SR\_IE] is set, the *sie0* signal from the interrupt controller is then automatically detected by the DDR controller, which immediately causes main memory to enter self-refresh mode. See Chip select n configuration 2 (DDR\_CSn\_CONFIG\_2), for further information on this bit.

The EIVPRn[PRIORITY] must be set to 0xF (highest priority) for self refresh to function.

See External interrupt n (IRQn) vector/priority register (PIC\_EIVPRn), for description of this register.

#### 8.7.2 Software Based Self-Refresh Scheme

The DDR controller also has a software-programmable bit, DDR\_SDRAM\_CFG\_2[FRC\_SR], that immediately puts main memory into self-refresh mode. See DDR SDRAM control configuration 2 (DDR\_DDR\_SDRAM\_CFG\_2) for a description of this register.

It is expected that a critical interrupt routine triggered by an external voltage sensing device will have time to set this bit.

## 8.7.3 Bypassing Re-initialization During Battery-Backed Operation

The DDR controller offers an initialization bypass feature (DDR\_SDRAM\_CFG[BI]), which system designers may use to prevent re-initialization of main memory during system power-on following an abnormal shutdown. See DDR SDRAM control configuration 2 (DDR\_DDR\_SDRAM\_CFG\_2) for information on this bit and DDR training initialization address (DDR\_DDR\_INIT\_ADDR) for a discussion of avoiding possible ECC errors in this mode.

Note that the DDR controller will automatically wait 200 DRAM cycles before issuing any command after the assertion of MCKE[0:1] when this mode is used.



# **Chapter 9 Programmable Interrupt Controller (PIC)**

This chapter describes the programmable interrupt controller (PIC) interrupt protocol, various types of interrupt sources controlled by the PIC, and the PIC registers with some programming guidelines.

#### 9.1 Introduction

This chapter describes the programmable interrupt controller (PIC) interrupt protocol, various types of interrupt sources controlled by the PIC, and the PIC registers with some programming guidelines.

The PIC conforms to the OpenPIC architecture. The interrupt controller provides multiprocessor interrupt management, and is responsible for receiving hardware-generated interrupts from different sources (both internal and external), prioritizing them, delivering them to the appropriate destination for servicing.

#### 9.1.1 Overview

The figure below is a block diagram showing the relationship of the various functional blocks and how the signals external to the PIC are connected to other blocks on the device, including the cores.



Not supported in single-processor implementations.

Figure 9-1. Interrupt sources block diagram features

The PIC has the following features:

• Support for the following interrupt sources:

- External-Off-chip signals, IRQ[ 0:6 ]
- Internal-These are on-chip sources from peripheral logic within the integrated device signaling error conditions that need to be addressed by software.
- Interrupts generated from within the PIC itself, which are as follows:
  - Global timers A and B internal to the PIC
    - Two groups of four global 32-bit timers clocked with the CCB clock or the RTC input. Timers within each group can be concatenated to time longer durations.
  - Interprocessor interrupts (IPI)-Intended for communication between different processor cores on the same device. (Can be used for self-interrupt in single-core devices.)
  - Message registers-From within the PIC. Triggered on register write, cleared on read. Used for interprocessor communication.
  - Shared message signaled registers-From within the PIC. Triggered on register write, cleared on read. Used for cross-program communication.
    - 32-bit message interrupt channels.
- Three types of programmable interrupt outputs:
  - External interrupt (*int0* and *int1*). Any of the PIC interrupt sources can be programmed to direct interrupt requests to *int0* and *int1*. Handling of such interrupt requests follows the OpenPIC specification, which guarantees that the highest priority interrupt supersedes lower priority interrupts. Interrupts routed to *int*, describes how the PIC logic handles these interrupts.
  - Critical interrupt (*cint0* and *cint1*). Connected to the respective e500 core's critical interrupt input.
  - IRO OUT B.

Interrupts routed to *cint* or IRQ\_OUT\_B, describes how the PIC logic supports this interrupt.

- Programming model compliant with the OpenPIC architecture.
  - Message, interprocessor and global timer interrupts. (Note that the interprocessor and global timer interrupts can only be routed to *int*.)
  - The following OpenPIC-defined features support only interrupts routed to the *int* signal:
    - Fully-nested interrupt delivery, guaranteeing that the interrupt source with the highest priority is given precedence over lower priority interrupts, including any that are in service.
    - 16 programmable interrupt priority levels
    - Support for identifying and handling spurious interrupts
- Support for two processors

#### Introduction

- Interrupts can be routed to processor core 0 or 1
- Multi-cast delivery mode for interprocessor and global timer interrupts allowing these interrupts to be routed to either core 0 or 1, or both cores
- Processor core initialization control
- Programmable resetting of the PIC through the global configuration register
- Support for connection of external interrupt controller device such as an 8259 programmable interrupt controller. In 8259 mode, an interrupt causes assertion of a local (that is, internal to the integrated device) interrupt output signal IRQ\_OUT\_B.
- Pass-through mode (PIC disabled) in which the PIC directs interrupts off-chip for external servicing. See Pass-through mode (GCR[M] = 0).

## 9.1.2 The PIC in multiple-processor implementations

In a multiprocessor implementation, the PIC is replicated for each core, and where necessary, the duplicated resources are indicated with a 0 or a 1.

For example, *int0* identifies the *int* signal to processor 0 and *int1* identifies the *int* signal to processor 1. Other resources associated with the cores are identified by the number. For example, setting PIR[P1] triggers a reset of core 1, and setting PIR[P0] triggers a reset of core 0.

However, where the distinction is not necessary, none is made and such resources are referred to generically. For example, the *int* signal refers to the behavior of either *int0* or *int1*.

In a multiprocessor system, it is possible for the PIC to direct interrupts to the other processor. This functionality is supported by certain multiprocessor aspects to the programming model. For example, an interrupt source in processor 0 can be programmed to target *int1* by setting the P1 bit in its destination register, xIDR*n*.

Note that although they are part of the programming model, such resources are reserved in a single-processor device.

## 9.1.3 Interrupts to the e500 processor core

The external interrupt signal, *int*, is the main interrupt output from the PIC to the processor core.

The interrupt sources can also specify the critical interrupt output, cint0 or cint1, if the corresponding xIDRn[CI0] or xIDRn[CI1] is set.

The PIC also defines the PIR, described in Processor core initialization register (PIC\_PIR) which can be used to reset the core. Processor core interrupts generated by the PIC are described in the table below.

Table 9-1. e500 processor interrupts generated outside the core-types and sources

| Core interrupt type       | Signaled by (input to core) | Sources                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|---------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PIC-Programmab            | le interrupts               |                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| External interrupt        | int                         | Generated by the PIC, as described in Interrupt sources.                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Critical interrupt        | cint                        | Generated by the PIC, as described in Interrupt sources.                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Other interrupts          | generated outside           | the core                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Machine check             | coren_mcp                   | NCP     SRESET      Assertion of <i>core_mcp</i> by global utilities block                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Unconditional debug event | coren_ude                   | UDE. Asserting UDE generates an unconditional debug exception type debug interrupt and sets a bit in the debug status register, DBSR[UDE], as described in the e500 Core Family Reference Manual.                                                                                                                                                                                                      |  |  |  |  |
| Reset                     | coren_hreset                | HRESET assertion (and negation)     core_hreset_req. Output from core-caused by writing to the core DBCR0[RST], as described in the e500 Reference Manual. This condition is additionally qualified with MSR[DE] and DBCR0[IDM] bits. Note that assertion of this signal causes a hard reset of the core only.      core_reset. Output from PIC. See Processor core initialization register (PIC_PIR). |  |  |  |  |

## 9.1.4 Modes of operation

Mixed or pass-through mode of operation is chosen by setting or clearing GCR[M].

This is described in Global configuration register (PIC\_GCR).

## 9.1.4.1 Mixed mode (GCR[M] = 1)

In mixed mode, external and internal interrupts are delivered using the normal priority and delivery mechanisms detailed in Flow of interrupt control.

## 9.1.4.2 Pass-through mode (GCR[M] = 0)

The PIC provides a mechanism to support alternate external interrupt controllers such as the PC/AT-compatible 8259 interrupt controller architecture.

#### Introduction

After a hard reset, the PIC defaults to pass-through mode, in which active-high interrupts from external source IRQ0 are passed directly to core 0 as shown in the figure below; all other external interrupt signals are ignored. Thus, the interrupt signal from an external interrupt controller can be connected to IRQ0 and cause direct interrupts to the processor core 0. The PIC does not perform a vector fetch from an external interrupt controller.



Figure 9-2. Pass-through mode example

When pass-through mode is enabled, the internally-generated interrupts shown in Table 9-2 are not forwarded to core 0. Instead, the PIC passes the raw interrupts from the internal sources to IRQ\_OUT\_B. Note that when the PCI Express controller is configured as an endpoint (EP) device, the *irq\_out* signal from the PIC may be used to automatically generate an outbound PCI Express MSI transaction toward the remote interrupt controller resource on the root complex (RC). See Hardware MSI generation.

Note that in pass-through mode, interrupts generated within the PIC (global timers, interprocessor, and message register interrupts) are disabled. If internal or PIC-generated interrupts must be reported internally to the processor, mixed mode must be used.

It is required that in pass-through mode the internal and external interrupt targets should be *int*, which is by default.

## 9.1.5 Interrupt sources

The PIC can receive separate interrupts from the following sources:

- External-Off-chip signals, IRQ[ 0:6 ]
- Internal-On-chip sources from peripheral logic within the integrated device. See Table 9-2.
- Global timers A and B internal to the PIC

- Interprocessor interrupts (IPI)-Intended for communication between different e500 processor cores on the same device. (Can be used for self-interrupt in single-core implementations.)
- Message registers-From within the PIC. Triggered on register write, cleared on read. Used for interprocessor communication.
- Shared message signaled registers-From within the PIC. Triggered on register write, cleared on read. Used for cross-program communication.

## 9.1.5.1 Interrupt routing-mixed mode

When an interrupt request is delivered to the PIC, the corresponding interrupt destination register is checked to determine where the request should be routed, as follows:

- If xIDR*n*[EP] = 1 (and all other destination bits are zero), the interrupt is routed off-chip to the external IRQ\_OUT\_B signal. If the PCI Express controller is in EP mode (and the corresponding xIDR*n*[EP] = 1), the controller automatically generates a PCI Express MSI transaction. See Hardware MSI generation.
- If either, but not both, xIDRn[CI0] or xIDRn[CI1] is set (and all other destination bits are zero), the interrupt is routed to *cint0* or *cint1*.
- If xIDRn[P0] is set (and all other destination bits are zero) the interrupt is routed to *int0*. Setting xIDRn[P1] likewise routs the interrupt to *int1*. In this case, the interrupt is latched by the interrupt pending register (IPR) and the interrupt flow is as described in Flow of interrupt control. Note that multicasting interrupts (global timer and interprocessor interrupts) can set both P0 and P1; other interrupt sources cannot.

## 9.1.5.2 Interrupt destinations

Following its reset (by default), the PIC directs all timer, shared message signaled, and interrupts from external and internal sources to *int* output (connected to the *int* signal of the e500 processor core).

Interprocessor and global timers interrupts can be programmed to be routed to either core's *int* signal or to both cores (multi-casting).

All other interrupts have more destination options, but only one destination can be chosen for a single non-multi-casting interrupt. Instead of being routed to *int*, these interrupts can be routed to the core through *cint* or can be directed to IRQ\_OUT\_B. These options are selected by writing to the EP or CI fields in the appropriate destination register.

Note that EP and CI are only supported for external and internal interrupts that does not support multi-casting.

# 9.1.5.3 Internal interrupt sources

The table below shows the assignments of the internal interrupt sources and how they are mapped to the registers that control them.

Only the internal interrupts used are listed; that is, the numbers are not consecutive.

Table 9-2. Internal interrupt assignments

| Internal Interrupt Number | Interrupt Source                                                |
|---------------------------|-----------------------------------------------------------------|
| 0                         | ORed Error Interrupt. See Table 9-3 for individual assignments. |
| 1                         | eTSEC 1 group 1 transmit                                        |
| 2                         | eTSEC 1 group 1 receive                                         |
| 3                         | eLBC general interrupt                                          |
| 4                         | DMA channel 1                                                   |
| 5                         | DMA channel 2                                                   |
| 6                         | DMA channel 3                                                   |
| 7                         | DMA channel 4                                                   |
| 8                         | eTSEC 1 group 1 error                                           |
| 9                         | eTSEC 3 group 1 transmit                                        |
| 10                        | eTSEC 3 group 1 receive                                         |
| 11                        | eTSEC 3 group 1 error                                           |
| 12                        | USB 1                                                           |
| 13                        | eTSEC 1 group 0 transmit                                        |
| 14                        | eTSEC 1 group 0 receive                                         |
| 15                        | eTSEC 3 group 0 transmit                                        |
| 16                        | eTSEC 3 group 0 receive                                         |
| 17                        | eTSEC 3 group 0 error                                           |
| 18                        | eTSEC 1 group 0 error                                           |
| 19                        | eTSEC 2 group 0 transmit                                        |
| 20                        | eTSEC 2 group 0 receive                                         |
| 21-23                     | Reserved                                                        |
| 24                        | eTSEC 2 group 0 error                                           |
| 25                        | Reserved                                                        |
| 26                        | DUART                                                           |
| 27                        | I <sup>2</sup> C controllers                                    |
| 28                        | Performance monitor                                             |
| 29                        | Security interrupt 1                                            |
| 30                        | Reserved                                                        |
| 31                        | QUICC Engine ports interrupts                                   |
| 32-34                     | Reserved                                                        |
| 35                        | eTSEC 2 group 1 transmit                                        |

Table 9-2. Internal interrupt assignments (continued)

| Internal Interrupt Number | Interrupt Source                                    |
|---------------------------|-----------------------------------------------------|
| 36                        | eTSEC 2 group 1 receive                             |
| 37-41                     | Reserved                                            |
| 42                        | Security interrupt 2                                |
| 43                        | eSPI                                                |
| 44                        | QUICC Engine low                                    |
| 45                        | Reserved                                            |
| 46                        | Reserved                                            |
| 47                        | QUICC Engine critical interrupt (QUICC Engine high) |
| 48-50                     | Reserved                                            |
| 51                        | eTSEC 2 group 1 error                               |
| 52                        | eTSEC 1 1588 timer                                  |
|                           | /QUICC Engine 1588 timer                            |
| 53                        | eTSEC 2 1588 timer                                  |
| 54                        | eTSEC 3 1588 timer                                  |
| 55                        | Reserved                                            |
| 56                        | eSDHC                                               |
| 57-63                     | Reserved                                            |

The ORed error interrupt summary is listed in the table below.

**Table 9-3. ORed Error Interrupt Sources** 

| Interrupt Source              | Section/Page                                       |
|-------------------------------|----------------------------------------------------|
| L2 Cache                      | L2 error detect register (L2_Cache_L2ERRDET)       |
| ECM (e500 coherency module)   | ECM error detect register (ECM_EEDR)               |
| Memory Controller Error       | Memory error detect (DDR_ERR_DETECT)               |
| PCI Express controller 1      | PCI Express error detect register (PEX_PEX_ERR_DR) |
| PCI Express controller 2      | PCI Express error detect register (PEX_PEX_ERR_DR) |
| TDM                           | TDMRER, TDMTER ,DMAES, and                         |
| Enhanced Local Bus Controller | Transfer error status register (eLBC_LTESR)        |

# 9.2 PIC external signal descriptions

The following sections describe the PIC signals.

# 9.2.1 Signal overview

The PIC external interface signals are described in Table 9-4.

There are distinct external interrupt request input signals and an interrupt request output signal IRQ\_OUT\_B.

As Table 9-4 shows, the IRQ inputs are also used for delivering INTx signals for the PCI Express root complexes.

## 9.2.2 Detailed signal descriptions

Table 9-4. Interrupt signals-detailed signal descriptions

| Signal        | l/<br>O |                      | Description                                                                                                                                                                                                                                                                                                                       |
|---------------|---------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQ[ 0:6 ]    | I       |                      | request 0-6. The polarity and sense of each of these signals is programmable. All of these inputs can asynchronously.                                                                                                                                                                                                             |
|               |         |                      | Some interrupt request signals IRQn may share PIC external interrupt registers with PCI Express INTx signaling. See PCI Express INTx/IRQn sharing.                                                                                                                                                                                |
|               |         | State<br>Meanin<br>g | Asserted-When an external interrupt signal is asserted (according to the programmed polarity), the PIC checks its priority and the interrupt is conditionally passed to the processor designated in the corresponding destination register. In pass-through mode, only interrupts detected on IRQ0 are passed directly to core 0. |
|               |         |                      | Negated-There is no incoming interrupt from that source.                                                                                                                                                                                                                                                                          |
|               |         | Timing               | Assertion-All of these inputs can be asserted asynchronously.                                                                                                                                                                                                                                                                     |
|               |         |                      | Negation-Interrupts programmed as level-sensitive must remain asserted until serviced. Timing requirements for edge-sensitive interrupts can be found in the Hardware Specifications.                                                                                                                                             |
| IRQ_OU<br>T_B | 0       |                      | request out. When the PIC is programmed in pass-through mode, this output reflects the raw generated by on-chip sources. See Modes of operation.                                                                                                                                                                                  |
|               |         | State<br>Meanin<br>g | Asserted-At least one interrupt is currently being signaled to the external system.  Negated-Indicates no interrupt source currently routed to IRQ_OUT_B.                                                                                                                                                                         |
|               |         | Timing               | Because external interrupts are asynchronous with respect to the system clock, both assertion and negation of IRQ_OUT_B occurs asynchronously with respect to the interrupt source. All timing given here is approximate.                                                                                                         |
|               |         |                      | Assertion-Internal interrupt source: 2 CCB clock cycles after interrupt occurs.                                                                                                                                                                                                                                                   |
|               |         |                      | External interrupt source: 4 cycles after interrupt occurs.                                                                                                                                                                                                                                                                       |
|               |         |                      | Message interrupts: 2 cycles after write to message register.                                                                                                                                                                                                                                                                     |
|               |         |                      | Negation-Follows interrupt source negation with the following delay:                                                                                                                                                                                                                                                              |
|               |         |                      | Internal interrupt: 2 CCB clock cycles                                                                                                                                                                                                                                                                                            |
|               |         |                      | External interrupt: 4 cycles.                                                                                                                                                                                                                                                                                                     |
|               |         |                      | Message interrupts: 2 cycles after message register cleared.                                                                                                                                                                                                                                                                      |

Table 9-4. Interrupt signals-detailed signal descriptions (continued)

| Signal                  | I/<br>O |             | Description                                                                                                                                                                                                                                                                                                                                                                                                              |                      |                                                                                                                                                                                                                                      |
|-------------------------|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCP0_B<br>and<br>MCP1_B | I       | if the core | check processor <i>n</i> . Assertion causes a machine check interrupt to the corresponding core. Note that e is not configured to process machine check interrupts (MSR[ME] = 0), assertion of MCPn_B causes neckstop condition. Note that internal sources for the internal <i>coren_mcp</i> can also cause a machine errupt to the processor core as described in Machine check summary register (GUTS_MCPSUMR) e 9-1. |                      |                                                                                                                                                                                                                                      |
|                         |         |             |                                                                                                                                                                                                                                                                                                                                                                                                                          | State<br>Meanin<br>g | Asserted-Integrated logic should direct the corresponding core to take a machine check interrupt or enter the checkstop state as directed by the MSR.  Negated-Machine check handling is not being requested by the external system. |
|                         |         | Timing      | Assertion-May occur at any time, asynchronous to any clock.  Negation-Because MCP_B n is edge-triggered, it can be negated one clock after its assertion.                                                                                                                                                                                                                                                                |                      |                                                                                                                                                                                                                                      |

# 9.3 PIC memory map/register definition

The PIC programmable register map occupies 256 Kbytes of memory-mapped space. Reading undefined portions of the memory map returns all zeros; writing has no effect. All PIC registers are 32 bits wide and, although located on 128-bit address boundaries, should be accessed only as 32-bit quantities.

The PIC address offset map is divided into three areas:

- 0xnn4\_0000-0xnn4\_FFF0-Global registers
- 0xnn5\_0000-0xnn5\_FFF0-Interrupt source configuration registers
- 0xnn6\_0000- 0xnn7\_FFF0 -Per-CPU registers

## PIC memory map

| Offset<br>address<br>(hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| 4_0000                     | Block revision register 1 (PIC_BRR1)            | 32                 | R      | 0040_0301h  | 9.3.1/412        |
| 4_0010                     | Block revision register 2 (PIC_BRR2)            | 32                 | R      | 0000_0001h  | 9.3.2/413        |
| 4_0040                     | Interprocessor n dispatch register (PIC_IPIDR0) | 32                 | W      | 0000_0000h  | 9.3.3/414        |
| 4_0050                     | Interprocessor n dispatch register (PIC_IPIDR1) | 32                 | W      | 0000_0000h  | 9.3.3/414        |
| 4_0060                     | Interprocessor n dispatch register (PIC_IPIDR2) | 32                 | W      | 0000_0000h  | 9.3.3/414        |
| 4_0070                     | Interprocessor n dispatch register (PIC_IPIDR3) | 32                 | W      | 0000_0000h  | 9.3.3/414        |
| 4_0080                     | Current task priority register (PIC_CTPR)       | 32                 | R/W    | 0000_000Fh  | 9.3.4/414        |
| 4_0090                     | Who am I register (PIC_WHOAMI)                  | 32                 | R      | See section | 9.3.5/415        |
| 4_00A0                     | Interrupt acknowledge register (PIC_IACK)       | 32                 | R      | 0000_0000h  | 9.3.6/416        |

| Offset address (hex) | Register name                                                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 4_00B0               | End of interrupt register (PIC_EOI)                               | 32                 | W      | 0000_0000h  | 9.3.7/417        |
| 4_1000               | Feature reporting register (PIC_FRR)                              | 32                 | R      | See section | 9.3.8/417        |
| 4_1020               | Global configuration register (PIC_GCR)                           | 32                 | R/W    | 0000_0000h  | 9.3.9/419        |
| 4_1080               | Vendor identification register (PIC_VIR)                          | 32                 | R      | 0000_0000h  | 9.3.10/420       |
| 4_1090               | Processor core initialization register (PIC_PIR)                  | 32                 | R/W    | 0000_0000h  | 9.3.11/420       |
| 4_10A0               | Interprocessor interrupt n vector/priority register (PIC_IPIVPR0) | 32                 | R/W    | 8000_0000h  | 9.3.12/421       |
| 4_10B0               | Interprocessor interrupt n vector/priority register (PIC_IPIVPR1) | 32                 | R/W    | 8000_0000h  | 9.3.12/421       |
| 4_10C0               | Interprocessor interrupt n vector/priority register (PIC_IPIVPR2) | 32                 | R/W    | 8000_0000h  | 9.3.12/421       |
| 4_10D0               | Interprocessor interrupt n vector/priority register (PIC_IPIVPR3) | 32                 | R/W    | 8000_0000h  | 9.3.12/421       |
| 4_10E0               | Spurious vector register (PIC_SVR)                                | 32                 | R/W    | 0000_FFFFh  | 9.3.13/422       |
| 4_10F0               | Timer frequency reporting register group X (PIC_TFRRA)            | 32                 | R/W    | 0000_0000h  | 9.3.14/422       |
| 4_1100               | Global timer n current count register group A (PIC_GTCCRA0)       | 32                 | R      | 0000_0000h  | 9.3.15/423       |
| 4_1110               | Global timer n base count register group A (PIC_GTBCRA0)          | 32                 | R/W    | 8000_0000h  | 9.3.16/424       |
| 4_1120               | Global timer n vector/priority register group A (PIC_GTVPRA0)     | 32                 | R/W    | 8000_0000h  | 9.3.17/425       |
| 4_1130               | Global timer n destination register group A (PIC_GTDRA0)          | 32                 | R/W    | 0000_0001h  | 9.3.18/426       |
| 4_1140               | Global timer n current count register group A (PIC_GTCCRA1)       | 32                 | R      | 0000_0000h  | 9.3.15/423       |
| 4_1150               | Global timer n base count register group A (PIC_GTBCRA1)          | 32                 | R/W    | 8000_0000h  | 9.3.16/424       |
| 4_1160               | Global timer n vector/priority register group A (PIC_GTVPRA1)     | 32                 | R/W    | 8000_0000h  | 9.3.17/425       |
| 4_1170               | Global timer n destination register group A (PIC_GTDRA1)          | 32                 | R/W    | 0000_0001h  | 9.3.18/426       |
| 4_1180               | Global timer n current count register group A (PIC_GTCCRA2)       | 32                 | R      | 0000_0000h  | 9.3.15/423       |
| 4_1190               | Global timer n base count register group A (PIC_GTBCRA2)          | 32                 | R/W    | 8000_0000h  | 9.3.16/424       |
| 4_11A0               | Global timer n vector/priority register group A (PIC_GTVPRA2)     | 32                 | R/W    | 8000_0000h  | 9.3.17/425       |
| 4_11B0               | Global timer n destination register group A (PIC_GTDRA2)          | 32                 | R/W    | 0000_0001h  | 9.3.18/426       |
| 4_11C0               | Global timer n current count register group A (PIC_GTCCRA3)       | 32                 | R      | 0000_0000h  | 9.3.15/423       |
| 4_11D0               | Global timer n base count register group A (PIC_GTBCRA3)          | 32                 | R/W    | 8000_0000h  | 9.3.16/424       |
| 4_11E0               | Global timer n vector/priority register group A (PIC_GTVPRA3)     | 32                 | R/W    | 8000_0000h  | 9.3.17/425       |
| 4_11F0               | Global timer n destination register group A (PIC_GTDRA3)          | 32                 | R/W    | 0000_0001h  | 9.3.18/426       |
| 4_1300               | Timer control register group n (PIC_TCRA)                         | 32                 | R/W    | 0000_0000h  | 9.3.19/426       |
| 4_1308               | External interrupt summary register (PIC_ERQSR)                   | 32                 | R      | 0000_0000h  | 9.3.20/429       |

| Offset address (hex) | Register name                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 4_1310               | IRQ_OUT_B summary register 0 (PIC_IRQSR0)                     | 32                 | R      | 0000_0000h  | 9.3.21/429       |
| 4_1320               | IRQ_OUT_B summary register 1 (PIC_IRQSR1)                     | 32                 | R      | 0000_0000h  | 9.3.22/430       |
| 4_1324               | IRQ_OUT_B summary register 2 (PIC_IRQSR2)                     | 32                 | R      | 0000_0000h  | 9.3.23/430       |
| 4_1330               | Critical interrupt summary register 0 (PIC_CISR0)             | 32                 | R      | 0000_0000h  | 9.3.24/431       |
| 4_1340               | Critical interrupt summary register 1 (PIC_CISR1)             | 32                 | R      | 0000_0000h  | 9.3.25/431       |
| 4_1344               | Critical interrupt summary register 2 (PIC_CISR2)             | 32                 | R      | 0000_0000h  | 9.3.26/432       |
| 4_1350               | Performance monitor n mask register 0 (PIC_PM0MR0)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.27/432       |
| 4_1360               | Performance monitor n mask register 1 (PIC_PM0MR1)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.28/433       |
| 4_1364               | Performance monitor n mask register 2 (PIC_PM0MR2)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.29/433       |
| 4_1370               | Performance monitor n mask register 0 (PIC_PM1MR0)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.27/432       |
| 4_1380               | Performance monitor n mask register 1 (PIC_PM1MR1)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.28/433       |
| 4_1384               | Performance monitor n mask register 2 (PIC_PM1MR2)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.29/433       |
| 4_1390               | Performance monitor n mask register 0 (PIC_PM2MR0)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.27/432       |
| 4_13A0               | Performance monitor n mask register 1 (PIC_PM2MR1)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.28/433       |
| 4_13A4               | Performance monitor n mask register 2 (PIC_PM2MR2)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.29/433       |
| 4_13B0               | Performance monitor n mask register 0 (PIC_PM3MR0)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.27/432       |
| 4_13C0               | Performance monitor n mask register 1 (PIC_PM3MR1)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.28/433       |
| 4_13C4               | Performance monitor n mask register 2 (PIC_PM3MR2)            | 32                 | R/W    | FFFF_FFFFh  | 9.3.29/433       |
| 4_1400               | Message register n (PIC_MSGR0)                                | 32                 | R/W    | 0000_0000h  | 9.3.30/434       |
| 4_1410               | Message register n (PIC_MSGR1)                                | 32                 | R/W    | 0000_0000h  | 9.3.30/434       |
| 4_1420               | Message register n (PIC_MSGR2)                                | 32                 | R/W    | 0000_0000h  | 9.3.30/434       |
| 4_1430               | Message register n (PIC_MSGR3)                                | 32                 | R/W    | 0000_0000h  | 9.3.30/434       |
| 4_1500               | Message enable register (PIC_MER)                             | 32                 | R/W    | 0000_0000h  | 9.3.31/434       |
| 4_1510               | Message status register (PIC_MSR)                             | 32                 | R/W    | 0000_0000h  | 9.3.32/435       |
| 4_1600               | Shared message signaled interrupt register n (PIC_MSIR0)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1610               | Shared message signaled interrupt register n (PIC_MSIR1)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1620               | Shared message signaled interrupt register n (PIC_MSIR2)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1630               | Shared message signaled interrupt register n (PIC_MSIR3)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1640               | Shared message signaled interrupt register n (PIC_MSIR4)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1650               | Shared message signaled interrupt register n (PIC_MSIR5)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1660               | Shared message signaled interrupt register n (PIC_MSIR6)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1670               | Shared message signaled interrupt register n (PIC_MSIR7)      | 32                 | R      | 0000_0000h  | 9.3.33/435       |
| 4_1720               | Shared message signaled interrupt status register (PIC_MSISR) | 32                 | R      | 0000_0000h  | 9.3.34/436       |
| 4_1740               | Shared message signaled interrupt index register (PIC_MSIIR)  | 32                 | W      | 0000_0000h  | 9.3.35/437       |
| 4_20F0               | Timer frequency reporting register group X (PIC_TFRRB)        | 32                 | R/W    | 0000_0000h  | 9.3.14/422       |
| 4_2100               | Global timer n current count register group B (PIC_GTCCRB0)   | 32                 | R      | 0000_0000h  | 9.3.36/438       |

| Offset           |                                                                   | 1                  |        |             |                  |
|------------------|-------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| address<br>(hex) | Register name                                                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
| 4_2110           | Global timer n base count register group B (PIC_GTBCRB0)          | 32                 | R/W    | 8000_0000h  | 9.3.37/439       |
| 4_2120           | Global timer n vector/priority register group B (PIC_GTVPRB0)     | 32                 | R/W    | 8000_0000h  | 9.3.38/440       |
| 4_2130           | Global timer n destination register group B (PIC_GTDRB0)          | 32                 | R/W    | 0000_0001h  | 9.3.39/441       |
| 4_2140           | Global timer n current count register group B (PIC_GTCCRB1)       | 32                 | R      | 0000_0000h  | 9.3.36/438       |
| 4_2150           | Global timer n base count register group B (PIC_GTBCRB1)          | 32                 | R/W    | 8000_0000h  | 9.3.37/439       |
| 4_2160           | Global timer n vector/priority register group B (PIC_GTVPRB1)     | 32                 | R/W    | 8000_0000h  | 9.3.38/440       |
| 4_2170           | Global timer n destination register group B (PIC_GTDRB1)          | 32                 | R/W    | 0000_0001h  | 9.3.39/441       |
| 4_2180           | Global timer n current count register group B (PIC_GTCCRB2)       | 32                 | R      | 0000_0000h  | 9.3.36/438       |
| 4_2190           | Global timer n base count register group B (PIC_GTBCRB2)          | 32                 | R/W    | 8000_0000h  | 9.3.37/439       |
| 4_21A0           | Global timer n vector/priority register group B (PIC_GTVPRB2)     | 32                 | R/W    | 8000_0000h  | 9.3.38/440       |
| 4_21B0           | Global timer n destination register group B (PIC_GTDRB2)          | 32                 | R/W    | 0000_0001h  | 9.3.39/441       |
| 4_21C0           | Global timer n current count register group B (PIC_GTCCRB3)       | 32                 | R      | 0000_0000h  | 9.3.36/438       |
| 4_21D0           | Global timer n base count register group B (PIC_GTBCRB3)          | 32                 | R/W    | 8000_0000h  | 9.3.37/439       |
| 4_21E0           | Global timer n vector/priority register group B (PIC_GTVPRB3)     | 32                 | R/W    | 8000_0000h  | 9.3.38/440       |
| 4_21F0           | Global timer n destination register group B (PIC_GTDRB3)          | 32                 | R/W    | 0000_0001h  | 9.3.39/441       |
| 4_2300           | Timer control register group n (PIC_TCRB)                         | 32                 | R/W    | 0000_0000h  | 9.3.19/426       |
| 4_2400           | Message register n (PIC_MSGRa4)                                   | 32                 | R/W    | 0000_0000h  | 9.3.40/441       |
| 4_2410           | Message register n (PIC_MSGRa5)                                   | 32                 | R/W    | 0000_0000h  | 9.3.40/441       |
| 4_2420           | Message register n (PIC_MSGRa6)                                   | 32                 | R/W    | 0000_0000h  | 9.3.40/441       |
| 4_2430           | Message register n (PIC_MSGRa7)                                   | 32                 | R/W    | 0000_0000h  | 9.3.40/441       |
| 4_2500           | Message enable register (PIC_MERa)                                | 32                 | R/W    | 0000_0000h  | 9.3.41/442       |
| 4_2510           | Message status register (PIC_MSRa)                                | 32                 | R/W    | 0000_0000h  | 9.3.42/443       |
| 5_0000           | External interrupt n (IRQn) vector/priority register (PIC_EIVPR0) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_0010           | External interrupt n (IRQn) destination register (PIC_EIDR0)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_0020           | External interrupt n (IRQn) vector/priority register (PIC_EIVPR1) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_0030           | External interrupt n (IRQn) destination register (PIC_EIDR1)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_0040           | External interrupt n (IRQn) vector/priority register (PIC_EIVPR2) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_0050           | External interrupt n (IRQn) destination register (PIC_EIDR2)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_0060           | External interrupt n (IRQn) vector/priority register (PIC_EIVPR3) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_0070           | External interrupt n (IRQn) destination register (PIC_EIDR3)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |

| Offset<br>address<br>(hex) | Register name                                                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 5_0080                     | External interrupt n (IRQn) vector/priority register (PIC_EIVPR4) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_0090                     | External interrupt n (IRQn) destination register (PIC_EIDR4)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_00A0                     | External interrupt n (IRQn) vector/priority register (PIC_EIVPR5) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_00B0                     | External interrupt n (IRQn) destination register (PIC_EIDR5)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_00C0                     | External interrupt n (IRQn) vector/priority register (PIC_EIVPR6) | 32                 | R/W    | 8000_0000h  | 9.3.43/443       |
| 5_00D0                     | External interrupt n (IRQn) destination register (PIC_EIDR6)      | 32                 | R/W    | 0000_0001h  | 9.3.44/445       |
| 5_0200                     | Internal interrupt n vector/priority register (PIC_IIVPR0)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0210                     | Internal interrupt n destination register (PIC_IIDR0)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0220                     | Internal interrupt n vector/priority register (PIC_IIVPR1)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0230                     | Internal interrupt n destination register (PIC_IIDR1)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0240                     | Internal interrupt n vector/priority register (PIC_IIVPR2)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0250                     | Internal interrupt n destination register (PIC_IIDR2)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0260                     | Internal interrupt n vector/priority register (PIC_IIVPR3)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0270                     | Internal interrupt n destination register (PIC_IIDR3)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0280                     | Internal interrupt n vector/priority register (PIC_IIVPR4)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0290                     | Internal interrupt n destination register (PIC_IIDR4)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_02A0                     | Internal interrupt n vector/priority register (PIC_IIVPR5)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_02B0                     | Internal interrupt n destination register (PIC_IIDR5)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_02C0                     | Internal interrupt n vector/priority register (PIC_IIVPR6)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_02D0                     | Internal interrupt n destination register (PIC_IIDR6)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_02E0                     | Internal interrupt n vector/priority register (PIC_IIVPR7)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_02F0                     | Internal interrupt n destination register (PIC_IIDR7)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0300                     | Internal interrupt n vector/priority register (PIC_IIVPR8)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0310                     | Internal interrupt n destination register (PIC_IIDR8)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0320                     | Internal interrupt n vector/priority register (PIC_IIVPR9)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0330                     | Internal interrupt n destination register (PIC_IIDR9)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0340                     | Internal interrupt n vector/priority register (PIC_IIVPR10)       | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0350                     | Internal interrupt n destination register (PIC_IIDR10)            | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0360                     | Internal interrupt n vector/priority register (PIC_IIVPR11)       | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0370                     | Internal interrupt n destination register (PIC_IIDR11)            | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0380                     | Internal interrupt n vector/priority register (PIC_IIVPR12)       | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0390                     | Internal interrupt n destination register (PIC_IIDR12)            | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_03A0                     | Internal interrupt n vector/priority register (PIC_IIVPR13)       | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_03B0                     | Internal interrupt n destination register (PIC_IIDR13)            | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_03C0                     | Internal interrupt n vector/priority register (PIC_IIVPR14)       | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_03D0                     | Internal interrupt n destination register (PIC_IIDR14)            | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |

| Offset address | Register name                                               | Width     | Access | Reset value    | Section/   |
|----------------|-------------------------------------------------------------|-----------|--------|----------------|------------|
| (hex)          | inegrete: maine                                             | (in bits) |        | 110000 10.10.0 | page       |
| 5_03E0         | Internal interrupt n vector/priority register (PIC_IIVPR15) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_03F0         | Internal interrupt n destination register (PIC_IIDR15)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0400         | Internal interrupt n vector/priority register (PIC_IIVPR16) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0410         | Internal interrupt n destination register (PIC_IIDR16)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0420         | Internal interrupt n vector/priority register (PIC_IIVPR17) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0430         | Internal interrupt n destination register (PIC_IIDR17)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0440         | Internal interrupt n vector/priority register (PIC_IIVPR18) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0450         | Internal interrupt n destination register (PIC_IIDR18)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0460         | Internal interrupt n vector/priority register (PIC_IIVPR19) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0470         | Internal interrupt n destination register (PIC_IIDR19)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0480         | Internal interrupt n vector/priority register (PIC_IIVPR20) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0490         | Internal interrupt n destination register (PIC_IIDR20)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_04A0         | Internal interrupt n vector/priority register (PIC_IIVPR21) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_04B0         | Internal interrupt n destination register (PIC_IIDR21)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_04C0         | Internal interrupt n vector/priority register (PIC_IIVPR22) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_04D0         | Internal interrupt n destination register (PIC_IIDR22)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_04E0         | Internal interrupt n vector/priority register (PIC_IIVPR23) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_04F0         | Internal interrupt n destination register (PIC_IIDR23)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0500         | Internal interrupt n vector/priority register (PIC_IIVPR24) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0510         | Internal interrupt n destination register (PIC_IIDR24)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0520         | Internal interrupt n vector/priority register (PIC_IIVPR25) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0530         | Internal interrupt n destination register (PIC_IIDR25)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0540         | Internal interrupt n vector/priority register (PIC_IIVPR26) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0550         | Internal interrupt n destination register (PIC_IIDR26)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0560         | Internal interrupt n vector/priority register (PIC_IIVPR27) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0570         | Internal interrupt n destination register (PIC_IIDR27)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0580         | Internal interrupt n vector/priority register (PIC_IIVPR28) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0590         | Internal interrupt n destination register (PIC_IIDR28)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_05A0         | Internal interrupt n vector/priority register (PIC_IIVPR29) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_05B0         | Internal interrupt n destination register (PIC_IIDR29)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_05C0         | Internal interrupt n vector/priority register (PIC_IIVPR30) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_05D0         | Internal interrupt n destination register (PIC_IIDR30)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_05E0         | Internal interrupt n vector/priority register (PIC_IIVPR31) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_05F0         | Internal interrupt n destination register (PIC_IIDR31)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0600         | Internal interrupt n vector/priority register (PIC_IIVPR32) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0610         | Internal interrupt n destination register (PIC_IIDR32)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |
| 5_0620         | Internal interrupt n vector/priority register (PIC_IIVPR33) | 32        | R/W    | 8080_0000h     | 9.3.45/446 |
| 5_0630         | Internal interrupt n destination register (PIC_IIDR33)      | 32        | R/W    | 0000_0001h     | 9.3.46/447 |

| Offset address | Register name                                               | Width (in bits) | Access | Reset value | Section/   |
|----------------|-------------------------------------------------------------|-----------------|--------|-------------|------------|
| (hex)          |                                                             | (III DIES)      |        |             | page       |
| 5_0640         | Internal interrupt n vector/priority register (PIC_IIVPR34) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0650         | Internal interrupt n destination register (PIC_IIDR34)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0660         | Internal interrupt n vector/priority register (PIC_IIVPR35) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0670         | Internal interrupt n destination register (PIC_IIDR35)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0680         | Internal interrupt n vector/priority register (PIC_IIVPR36) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0690         | Internal interrupt n destination register (PIC_IIDR36)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_06A0         | Internal interrupt n vector/priority register (PIC_IIVPR37) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_06B0         | Internal interrupt n destination register (PIC_IIDR37)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_06C0         | Internal interrupt n vector/priority register (PIC_IIVPR38) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_06D0         | Internal interrupt n destination register (PIC_IIDR38)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_06E0         | Internal interrupt n vector/priority register (PIC_IIVPR39) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_06F0         | Internal interrupt n destination register (PIC_IIDR39)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0700         | Internal interrupt n vector/priority register (PIC_IIVPR40) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0710         | Internal interrupt n destination register (PIC_IIDR40)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0720         | Internal interrupt n vector/priority register (PIC_IIVPR41) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0730         | Internal interrupt n destination register (PIC_IIDR41)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0740         | Internal interrupt n vector/priority register (PIC_IIVPR42) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0750         | Internal interrupt n destination register (PIC_IIDR42)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0760         | Internal interrupt n vector/priority register (PIC_IIVPR43) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0770         | Internal interrupt n destination register (PIC_IIDR43)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0780         | Internal interrupt n vector/priority register (PIC_IIVPR44) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0790         | Internal interrupt n destination register (PIC_IIDR44)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_07A0         | Internal interrupt n vector/priority register (PIC_IIVPR45) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_07B0         | Internal interrupt n destination register (PIC_IIDR45)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_07C0         | Internal interrupt n vector/priority register (PIC_IIVPR46) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_07D0         | Internal interrupt n destination register (PIC_IIDR46)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_07E0         | Internal interrupt n vector/priority register (PIC_IIVPR47) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_07F0         | Internal interrupt n destination register (PIC_IIDR47)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0800         | Internal interrupt n vector/priority register (PIC_IIVPR48) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0810         | Internal interrupt n destination register (PIC_IIDR48)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0820         | Internal interrupt n vector/priority register (PIC_IIVPR49) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0830         | Internal interrupt n destination register (PIC_IIDR49)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0840         | Internal interrupt n vector/priority register (PIC_IIVPR50) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0850         | Internal interrupt n destination register (PIC_IIDR50)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0860         | Internal interrupt n vector/priority register (PIC_IIVPR51) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0870         | Internal interrupt n destination register (PIC_IIDR51)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |
| 5_0880         | Internal interrupt n vector/priority register (PIC_IIVPR52) | 32              | R/W    | 8080_0000h  | 9.3.45/446 |
| 5_0890         | Internal interrupt n destination register (PIC_IIDR52)      | 32              | R/W    | 0000_0001h  | 9.3.46/447 |

| Offset address (hex) | Register name                                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|--------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 5_08A0               | Internal interrupt n vector/priority register (PIC_IIVPR53)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_08B0               | Internal interrupt n destination register (PIC_IIDR53)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_08C0               | Internal interrupt n vector/priority register (PIC_IIVPR54)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_08D0               | Internal interrupt n destination register (PIC_IIDR54)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_08E0               | Internal interrupt n vector/priority register (PIC_IIVPR55)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_08F0               | Internal interrupt n destination register (PIC_IIDR55)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0900               | Internal interrupt n vector/priority register (PIC_IIVPR56)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0910               | Internal interrupt n destination register (PIC_IIDR56)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0920               | Internal interrupt n vector/priority register (PIC_IIVPR57)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0930               | Internal interrupt n destination register (PIC_IIDR57)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0940               | Internal interrupt n vector/priority register (PIC_IIVPR58)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0950               | Internal interrupt n destination register (PIC_IIDR58)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0960               | Internal interrupt n vector/priority register (PIC_IIVPR59)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0970               | Internal interrupt n destination register (PIC_IIDR59)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_0980               | Internal interrupt n vector/priority register (PIC_IIVPR60)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_0990               | Internal interrupt n destination register (PIC_IIDR60)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_09A0               | Internal interrupt n vector/priority register (PIC_IIVPR61)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_09B0               | Internal interrupt n destination register (PIC_IIDR61)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_09C0               | Internal interrupt n vector/priority register (PIC_IIVPR62)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_09D0               | Internal interrupt n destination register (PIC_IIDR62)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_09E0               | Internal interrupt n vector/priority register (PIC_IIVPR63)        | 32                 | R/W    | 8080_0000h  | 9.3.45/446       |
| 5_09F0               | Internal interrupt n destination register (PIC_IIDR63)             | 32                 | R/W    | 0000_0001h  | 9.3.46/447       |
| 5_1600               | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR0) | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_1610               | Messaging interrupt n (MSGn) destination register (PIC_MIDR0)      | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_1620               | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR1) | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_1630               | Messaging interrupt n (MSGn) destination register (PIC_MIDR1)      | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_1640               | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR2) | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_1650               | Messaging interrupt n (MSGn) destination register (PIC_MIDR2)      | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_1660               | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR3) | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_1670               | Messaging interrupt n (MSGn) destination register (PIC_MIDR3)      | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_1680               | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR4) | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |

| Offset<br>address<br>(hex) | Register name                                                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 5_1690                     | Messaging interrupt n (MSGn) destination register (PIC_MIDR4)              | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_16A0                     | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR5)         | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_16B0                     | Messaging interrupt n (MSGn) destination register (PIC_MIDR5)              | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_16C0                     | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR6)         | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_16D0                     | Messaging interrupt n (MSGn) destination register (PIC_MIDR6)              | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_16E0                     | Messaging interrupt n (MSGn) vector/priority register (PIC_MIVPR7)         | 32                 | R/W    | 8000_0000h  | 9.3.47/448       |
| 5_16F0                     | Messaging interrupt n (MSGn) destination register (PIC_MIDR7)              | 32                 | R/W    | 0000_0001h  | 9.3.48/449       |
| 5_1C00                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR0) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1C10                     | Shared message signaled interrupt destination register n (PIC_MSIDR0)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1C20                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR1) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1C30                     | Shared message signaled interrupt destination register n (PIC_MSIDR1)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1C40                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR2) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1C50                     | Shared message signaled interrupt destination register n (PIC_MSIDR2)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1C60                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR3) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1C70                     | Shared message signaled interrupt destination register n (PIC_MSIDR3)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1C80                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR4) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1C90                     | Shared message signaled interrupt destination register n (PIC_MSIDR4)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1CA0                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR5) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1CB0                     | Shared message signaled interrupt destination register n (PIC_MSIDR5)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1CC0                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR6) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |
| 5_1CD0                     | Shared message signaled interrupt destination register n (PIC_MSIDR6)      | 32                 | R/W    | See section | 9.3.50/451       |
| 5_1CE0                     | Shared message signaled interrupt vector/priority register n (PIC_MSIVPR7) | 32                 | R/W    | 8000_0000h  | 9.3.49/450       |

| Offset<br>address<br>(hex) | Register name                                                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|--------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 5_1CF0                     | Shared message signaled interrupt destination register n (PIC_MSIDR7)          | 32                 | R/W    | See section | 9.3.50/451       |
| 6_0040                     | Processor core 0 interprocessor n dispatch register (PIC_IPIDR_CPU00)          | 32                 | W      | 0000_0000h  | 9.3.51/452       |
| 6_0050                     | Processor core 0 interprocessor n dispatch register (PIC_IPIDR_CPU01)          | 32                 | W      | 0000_0000h  | 9.3.51/452       |
| 6_0060                     | Processor core 0 interprocessor n dispatch register (PIC_IPIDR_CPU02)          | 32                 | W      | 0000_0000h  | 9.3.51/452       |
| 6_0070                     | Processor core 0 interprocessor n dispatch register (PIC_IPIDR_CPU03)          | 32                 | W      | 0000_0000h  | 9.3.51/452       |
| 6_0080                     | Processor core current task priority register 0 Processor core (PIC_CTPR_CPU0) | 32                 | R/W    | 0000_000Fh  | 9.3.52/452       |
| 6_0090                     | Processor core 0 who am I register (PIC_WHOAMI_CPU0)                           | 32                 | R      | See section | 9.3.53/453       |
| 6_00A0                     | Processor core 0 interrupt acknowledge register (PIC_IACK_CPU0)                | 32                 | R      | 0000_0000h  | 9.3.54/454       |
| 6_00B0                     | Processor core 0 end of interrupt register (PIC_EOI_CPU0)                      | 32                 | W      | 0000_0000h  | 9.3.55/455       |
| 6_1040                     | Processor core 1 interprocessor n dispatch register (PIC_IPIDR_CPU10)          | 32                 | W      | 0000_0000h  | 9.3.56/456       |
| 6_1050                     | Processor core 1 interprocessor n dispatch register (PIC_IPIDR_CPU11)          | 32                 | W      | 0000_0000h  | 9.3.56/456       |
| 6_1060                     | Processor core 1 interprocessor n dispatch register (PIC_IPIDR_CPU12)          | 32                 | W      | 0000_0000h  | 9.3.56/456       |
| 6_1070                     | Processor core 1 interprocessor n dispatch register (PIC_IPIDR_CPU13)          | 32                 | W      | 0000_0000h  | 9.3.56/456       |
| 6_1080                     | Processor core 1 current task priority register (PIC_CTPR_CPU1)                | 32                 | R/W    | 0000_000Fh  | 9.3.57/456       |
| 6_1090                     | Processor core 1 who am I register (PIC_WHOAMI_CPU1)                           | 32                 | R      | See section | 9.3.58/457       |
| 6_10A0                     | Processor core 1 interrupt acknowledge register (PIC_IACK_CPU1)                | 32                 | R      | 0000_0000h  | 9.3.59/458       |
| 6_10B0                     | Processor core 1 end of interrupt register (PIC_EOI_CPU1)                      | 32                 | W      | 0000_0000h  | 9.3.60/459       |

# 9.3.1 Block revision register 1 (PIC\_BRR1)

BRR1 provides information about the PIC IP block.

Address: 4\_0000h base + 0h offset = 4\_0000h



## PIC\_BRR1 field descriptions

| Field         | Description                         |
|---------------|-------------------------------------|
| 0–15<br>IPID  | IP block ID.                        |
| 16–23<br>IPMJ | The major revision of the IP block. |
| 24–31<br>IPMN | The minor revision of the IP block. |

# 9.3.2 Block revision register 2 (PIC\_BRR2)

BRR2 provides information about the IP block integration option and IP block configuration options.

Address: 4\_0000h base + 10h offset = 4\_0010h



## PIC\_BRR2 field descriptions

| Field           | Description                      |
|-----------------|----------------------------------|
| 0–7             | This field is reserved. Reserved |
| 8–15<br>IPINTO  | IP block integration options     |
| 16–23<br>-      | This field is reserved. Reserved |
| 24–31<br>IPCFGO | IP block configuration options   |

# 9.3.3 Interprocessor n dispatch register (PIC\_IPIDRn)

The figure below shows the four IPIDRs, one for each interprocessor interrupt channel. Writing to an IPIDR with a bit set causes a self interrupt for a single-core device. Because external bus masters can write to these registers, this feature can serve as a doorbell type interrupt.



### PIC\_IPIDRn field descriptions

| Field    | Description                                                                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29     | This field is reserved. Reserved                                                                                                                    |
| 30<br>P1 | Processor core 1. Specifies if processor core 1 receives the interrupt. This interrupt is multicasting, so both P0 and P1 can be set.               |
|          | NOTE: Reserved in single-processor implementations.  O Processor core 1 does not receive the interrupt  1 Directs the interrupt to processor core 1 |
| 31<br>P0 | Processor core 0 . Determines if processor core 0 receives the interrupt.                                                                           |
|          | 0 Processor core 0 does not receive the interrupt.                                                                                                  |
|          | 1 Directs the interrupt to processor core 0.                                                                                                        |

# 9.3.4 Current task priority register (PIC\_CTPR)

There is one CTPR per processor core on this device.

### **NOTE**

CTPR has meaning only for interrupts routed to int.

Software must write the priority of the current processor core task in the CTPR for each core. The PIC uses this value for comparison with the priority of incoming interrupts. Given several concurrent incoming interrupts, the highest priority interrupt is asserted to that core if the following apply:

- The interrupt is not masked.
- The priority of the interrupt is higher than the values in the corresponding CTPR[TASKP] and ISR.





### PIC\_CTPR field descriptions

| Field          | Description                                                                                                                                                       |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–27<br>-      | This field is reserved. Reserved                                                                                                                                  |  |  |
| 28–31<br>TASKP | Task priority. Indicates the threshold that individual interrupt priorities must exceed for the interrupt request to be serviced.                                 |  |  |
|                | 0000-1111 xVPRn[PRIORITY] must exceed this value for the interrupt request to be serviced. Note the following special cases:                                      |  |  |
|                | Lowest priority. All interrupts except those whose priority are 0 can be serviced.                                                                                |  |  |
|                | Highest priority. No interrupts are signaled to that processor core. Hardware selects this value on a device hard reset or when the corresponding PIR[Pn] is set. |  |  |

# 9.3.5 Who am I register (PIC\_WHOAMI)

The processor core WHOAMI *n* register can be read by a processor core to determine its physical connection to the PIC. The value returned when reading this register may be used to determine the value for the destination masks used for dispatching interrupts.





### PIC\_WHOAMI field descriptions

| Field       | Description                                                                              |  |
|-------------|------------------------------------------------------------------------------------------|--|
| 0–26        | This field is reserved.                                                                  |  |
| -           | Reserved                                                                                 |  |
| 27–31<br>ID | Returns the ID of the processor core reading this register. Does not always return zero. |  |
|             | 0_0000 Processor core 0                                                                  |  |
|             | 0_0001 Processor core 1. (Value not supported in single-processor implementations.)      |  |
|             | 1_1111 All other devices                                                                 |  |

# 9.3.6 Interrupt acknowledge register (PIC\_IACK) NOTE

IACK has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

In systems based on processors built on Power Architecture technology, the interrupt acknowledge function occurs as an explicit read operation to a memory-mapped interrupt acknowledge register (IACK). Each processor core has an IACK register assigned to it. Reading IACK returns the interrupt vector corresponding to the highest priority pending interrupt. Reading IACK also has the following side effects:

- The associated field in the corresponding interrupt pending register (IPR) is cleared for edge-sensitive interrupts. See Interrupts routed to *int*.
- The corresponding in-service register (ISR) is updated.
- The corresponding *int* output signal from the PIC is negated.

Reading IACK when no interrupt is pending returns the spurious vector value, as described in Spurious vector register (PIC\_SVR).

Address: 4\_0000h base + A0h offset = 4\_00A0h



### PIC\_IACK field descriptions

| Field           | Description                                               |
|-----------------|-----------------------------------------------------------|
| 0–15<br>-       | This field is reserved. Reserved                          |
| 16–31<br>VECTOR | Interrupt vector. Vector of the highest pending interrupt |

# 9.3.7 End of interrupt register (PIC\_EOI)

#### NOTE

EOI has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

Each core is assigned an EOI register. Writing to EOI signals the end of processing for the highest-priority interrupt (routed to *int*) currently in service. It also updates the corresponding ISR *n* by retiring the highest priority interrupt. Data values written to EOI are ignored, and zero is assumed.





### PIC\_EOI field descriptions

| Field             | Description                      |
|-------------------|----------------------------------|
| 0–27<br>-         | This field is reserved. Reserved |
| 28–31<br>EOI_CODE | 0000 (write only)                |

## 9.3.8 Feature reporting register (PIC\_FRR)

FRR provides information about interrupt and e500 processor core configurations. It also informs the programming environment of the controller version.

Address: 4\_0000h base + 1000h offset = 4\_1000h



<sup>\*</sup> Notes:

• NCPU field: See description for NCPU for reset value.

## PIC memory map/register definition

# PIC\_FRR field descriptions

| Field         | Description                                                                                                                                                                                                                                              |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4           | This field is reserved. Reserved                                                                                                                                                                                                                         |
| 5–15<br>NIRQ  | Number of interrupts. Holds the binary value of the number of the highest interrupt source supported minus one.                                                                                                                                          |
|               | The value is 102 (0x6B or 0b000_0110_1011), because this device supports 103 interrupts: 7 external sources, 64 internal sources (see Table 9-4), 8 timer sources, 8 interprocessor sources, 8 messaging sources, and 8 shared message signaled sources. |
|               | A zero in this field corresponds to one source.                                                                                                                                                                                                          |
| 16–18<br>-    | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                      |
| 19–23<br>NCPU | Number of CPUs. The number of the highest physical CPUs (or e500 processor cores) supported minus one.                                                                                                                                                   |
|               | 00000 Single core-core0 00001 Two cores-core0 and core1                                                                                                                                                                                                  |
| 24–31<br>VID  | Version ID. Reports the OpenPIC specification revision level supported by this interrupt controller implementation. The VID field's value of two (0x02) corresponds to revision 1.2 which is the revision level currently supported.                     |

# 9.3.9 Global configuration register (PIC\_GCR)

0

GCR controls the PIC's operating mode, and allows software to reset the PIC.





## PIC\_GCR field descriptions

0

| Field     | Description                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0<br>RST  | Reset. Setting RST forces the PIC to be reset. Cleared automatically when the reset sequence is complete. See Resetting the PIC for more information.                                                                                                                                                                          |  |  |  |  |
| 1 -       | his field is reserved. Reserved                                                                                                                                                                                                                                                                                                |  |  |  |  |
| 2<br>M    | <ul> <li>Mode. PIC operating mode. Modes of operation provides details about these modes.</li> <li>Pass-through mode. On-chip PIC is disabled and interrupts detected on IRQ0 are passed directly to core 0.</li> <li>Mixed mode. Interrupts are handled by the normal priority and delivery mechanisms of the PIC.</li> </ul> |  |  |  |  |
| 3–31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                               |  |  |  |  |

Reset

0

0

# 9.3.10 Vendor identification register (PIC\_VIR)

VIR is defined by the OpenPIC specifications and is provided for compliance. The zero value for VIR[VENDORID] indicates a generic OpenPIC-compliant device, which makes the other VIR fields meaningless.





### PIC\_VIR field descriptions

| Field              | Description                                                                                                                 |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0–7<br>-           | This field is reserved. Reserved                                                                                            |  |  |  |  |
| 8–15<br>STEP       | Stepping. Indicates the silicon revision for this device. Has no meaning if VENDOR_ID value is zero.                        |  |  |  |  |
| 16-23<br>DEVICE_ID | Device identification. Vendor-specified identifier for this device. Has no meaning if VENDOR_ID is zero.                    |  |  |  |  |
| 24–31<br>VENDOR_ID | Vendor identification. Specifies the manufacturer of this part. A value of zero implies a generic OpenPIC-compliant device. |  |  |  |  |

# 9.3.11 Processor core initialization register (PIC\_PIR)

PIR provides a way for software to generate a core reset. Setting P1 or P0 causes the respective *core* 0 \_*hreset* or*core1*\_*hreset* signal to assert. Note that after requesting a core reset using this register the applicable bit should not be cleared until the requested core reset has occurred. However, if one core is used to reset another one, the core being reset can effectively be held off indefinitely from issuing its initial boot vector fetch to the platform by leaving its appropriate PIR[Px] bit asserted. Clearing it releases the core to fetch.

Note that although the OpenPIC architecture was defined to support up to 32 processing cores, only fields corresponding to the number of cores on the device are implemented.

Address: 4\_0000h base + 1090h offset = 4\_1090h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013



### PIC\_PIR field descriptions

| Field     | Description                                                                                                                                     |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0–29<br>- | This field is reserved. Reserved                                                                                                                |  |  |  |  |
|           | Processor core 1 reset. Setting this bit causes the PIC to assert the <i>core1_hreset</i> signal. Reserved in single-processor implementations. |  |  |  |  |
| 31<br>P0  | Processor core 0 reset. Setting this bit causes the PIC to assert the <i>core0_hreset</i> signal.                                               |  |  |  |  |

# 9.3.12 Interprocessor interrupt n vector/priority register (PIC\_IPIVPRn)

IPIVPRs contain the interrupt vector and priority fields for the four interprocessor interrupt channels. There is one vector/priority register per channel. The VECTOR and PRIORITY values should not be changed while IPIVPR n [A] is set. See Flow of interrupt control for information on IPR and ISR.

Address: 4\_0000h base + 10A0h offset + (16d × i), where i=0d to 3d



## PIC\_IPIVPRn field descriptions

| Field    | Description                                                                                                                                       |  |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>MSK | Mask. Mask interrupts to <i>int</i> from this source.  O An interrupt request is generated if the corresponding IPR bit is set.                   |  |  |  |
|          | 1 Further interrupts from this source are disabled.                                                                                               |  |  |  |
| 1<br>A   | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set. |  |  |  |

### PIC\_IPIVPRn field descriptions (continued)

| Field             | Description                                                                                                                                                                                                             |  |  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                   | No current interrupt activity associated with this source.                                                                                                                                                              |  |  |  |  |  |
|                   | 1 The interrupt field for this source is set in the IPR or ISR.                                                                                                                                                         |  |  |  |  |  |
| 2–11              | This field is reserved.                                                                                                                                                                                                 |  |  |  |  |  |
| -                 | Reserved                                                                                                                                                                                                                |  |  |  |  |  |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |  |  |  |  |  |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |  |  |  |  |  |

## 9.3.13 Spurious vector register (PIC\_SVR)

SVR contains the 16-bit vector returned to the e500 processor core when the corresponding IACK register is read for a spurious interrupt.

Address: 4\_0000h base + 10E0h offset = 4\_10E0h



### PIC\_SVR field descriptions

| Field | Description                                                                                                                                                                                           |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       | This field is reserved. Reserved                                                                                                                                                                      |  |  |  |
|       | Spurious interrupt vector. Value returned when IACK is read during a spurious vector fetch. Spurious vector generation gives information about the conditions that may cause a spurious vector fetch. |  |  |  |

# 9.3.14 Timer frequency reporting register group X (PIC\_TFRRn)

The TFRRs are written by software to report the clocking frequency of the PIC timers. Note that although TFRRs are read/write, the PIC ignores the register values.

Address:  $4_{0000h}$  base + 10F0h offset + (4096d × i), where i=0d to 1d



## PIC\_TFRRn field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       | Timer frequency (in ticks/second (Hz)). Used to communicate the frequency of the global timers' clock source, (either the CCB clock or the frequency of the RTC signal), to user software. TFRRx is set only by software for later use by other applications and its value in no way affects the operating frequency of the global timers. The timers operate at a ratio of this clock frequency, as set by TCRx[CLKR]. See Timer control register group n (PIC_TCRn). |  |  |  |  |

# 9.3.15 Global timer n current count register group A (PIC\_GTCCRAn)

The GTCCRs contain the current count for each of the four PIC timers in each of the two groups.





### PIC\_GTCCRAn field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0<br>TOG      | Toggle. Toggles when the current count decrements to zero. Cleared when GTBCR xn [CI] goes from 1 to 0.                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 1–31<br>COUNT | Current count. Decremented while GTBCR $xn$ [CI] is zero. When the timer count reaches zero, an interrupt is generated (provided it is not masked), the toggle bit is inverted, and the count is reloaded. For non-cascaded timers, the reload value is the contents of the corresponding GTBCR $xn$ . Cascaded timers are reloaded with either all ones, or the GTBCR $xn$ contents, depending on the value of TCRn[ROVR]. See Timer control register group n (PIC_TCR $n$ ), for more details. |  |  |  |  |

# 9.3.16 Global timer n base count register group A (PIC\_GTBCRAn)

The GTBCRs contain the base counts for each of the four PIC timers in each of the two groups. This value is reloaded into the corresponding GTCCR xn when the current count reaches zero. Note that when zero is written to the base count field, (and GTCCR xn [CI] = 0), the timer generates an interrupt on every timer cycle.





### PIC\_GTBCRAn field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                 |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>CI          | Count inhibit. Always set following reset  0 Counting enabled 1 Counting inhibited                                                                                                                                                                                                          |  |  |  |
| 1–31<br>BASE_CNT | Base count. When CI transitions from 1 to 0, this value is copied into the corresponding GTCCR <i>xn</i> and the toggle bit is cleared. If CI is already cleared (counting is in progress), the base count is copied to the GTCCR <i>xn</i> at the next zero crossing of the current count. |  |  |  |

# 9.3.17 Global timer n vector/priority register group A (PIC\_GTVPRAn)

The GTVPRs contain the interrupt vector and the interrupt priority values for the timers. They also contain the mask and activity fields for all the timers. See Flow of interrupt control for information on IPR and ISR.



### PIC\_GTVPRAn field descriptions

| Field             | Description                                                                                                                                                                                                             |  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0<br>MSK          | Mask. Mask interrupts to <i>int</i> from this source.  O An interrupt request is generated if the corresponding IPR bit is set.                                                                                         |  |  |  |  |
|                   | 1 Further interrupts from this source are disabled.                                                                                                                                                                     |  |  |  |  |
| 1<br>A            | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set.                                                                       |  |  |  |  |
|                   | <ul><li>No current interrupt activity associated with this source.</li><li>The interrupt field for this source is set in the IPR or ISR.</li></ul>                                                                      |  |  |  |  |
| 2–11<br>-         | This field is reserved. Reserved                                                                                                                                                                                        |  |  |  |  |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |  |  |  |  |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |  |  |  |  |

## 9.3.18 Global timer n destination register group A (PIC\_GTDRAn)

The GTDR *xn* registers control the destination (core) to which each timer's interrupt is directed. Note that GTDR *xn* bits can be set independent of each other and that either P1 or P0 or both can be set for this type of interrupt.



### PIC\_GTDRAn field descriptions

| Field     | Description                                                                                                                                                                                     |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0–29<br>- | This field is reserved. Reserved                                                                                                                                                                |  |  |  |  |
| 30<br>P1  | Processor core 1. This interrupt is multicasting, so both P0 and P1 can be set.  NOTE: Reserved in single-processor implementations.                                                            |  |  |  |  |
|           | <ul> <li>0 Processor core 1 does not receive this interrupt</li> <li>1 Directs the timer interrupt to processor core 1</li> </ul>                                                               |  |  |  |  |
| 31<br>P0  | Processor core 0 . Default destination after PIC is reset. Both P0 and P1 can be set.  0 Processor core 0 does not receive this interrupt.  1 Directs the timer interrupt to processor core 0 . |  |  |  |  |

## 9.3.19 Timer control register group n (PIC\_TCRn)

The TCR *n* registers provide various configuration options such as count frequency and roll-over behavior for the timers.

There are two choices for the clock source for the timers: a selectable frequency ratio from the CCB bus clock, or the RTC signal. TCRs can be cascaded to create timers larger than the default 31-bit global timers. Timer cascade fields allow configuration of up to two 63-bit timers, one 95-bit timer, or one 127-bit timer (within each group).

With one exception mentioned below, the value reloaded into a timer is determined by its roll-over control field, TCR n [ROVR]. Setting TCR n [ROVR] causes its GTCCR xn to roll over to all ones when the count reaches zero. This is equivalent to reloading the count register with 0xFFFF\_FFFF instead of its base count value. Clearing a timer's associated ROVR bit ensures the timer always reloads with its base count value.

When timers are cascaded, the last (most significant) counter in the cascade also affects their roll-over behavior. Cascaded timers always reload their base count when the most significant counter has decremented to zero, regardless of the TCR n [ROVR] settings.

For example, timers 0-2 can be cascaded to generate one interrupt per hour. Given a CCB clock frequency of 333 MHz, letting the timer clock frequency default to 1/8 <sup>th</sup> the system clock, (TCR n [CLKR] = 0 sets a clock ratio of 8), provides a basic input of 41.625 MHz to timer 0. Setting timer 0 to count 41,625,000 (0x27B\_25A8) timer clock cycles generates one output per second. Setting both timers 1 and 2 to 59, and cascading all three timers, generates one interrupt every hour from timer 2.

Table 9-49. Parameters for Hourly Interrupt Timer Cascade Example

| System Clock | Clock Ratio | Timer Clock | Timer 0 Count                             | Timer 1 Count                 | Timer 2 Count    |
|--------------|-------------|-------------|-------------------------------------------|-------------------------------|------------------|
| 333 MHz      | 1 / 8       | 41.625 MHz  | 41.625 x 10 <sup>6</sup><br>(0x027B_25A8) | 59 <sup>1</sup> (0x0000_0036) | 59 (0x0000_0036) |

- 1. Counting down from 59 through 0 requires 60 ticks.
- Counting down from 59 through 0 requires 60 ticks.
- 1. Counting down from 59 through 0 requires 60 ticks.

(41.625 x 106 ticks/sec) × (60 sec/min) × (60 min/hr) = total ticks/hr generating 1 interrupt/hr

Figure 9-47. Example Calculation for Cascaded Timers

Address:  $4_{0000h}$  base + 1300h offset + (4096d × i), where i=0d to 1d



PIC\_TCRn field descriptions

| Field       | Description                                                                                                                                                                                                    |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4         | This field is reserved. Reserved                                                                                                                                                                               |
| 5–7<br>ROVR | Roll-over control for cascaded timers only. Specifies behavior when count reaches zero by identifying the source of the reload value. Cascaded timers are always reloaded with their base count value when the |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# PIC\_TCRn field descriptions (continued)

| Field         | Description                                                                                                                                                          |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | more significant timer in the cascade (the upstream timer) is zero. Bits 5-7 correspond to timers 2-0. Note that global timer 3 always reloads with its GTBCR $xn$ . |
|               | The timer does not roll over. When the count reaches zero, GTCCR xn is reloaded with the GTBCR xn value.                                                             |
|               | Timer rolls over at zero to all ones. (When the count reaches zero, GTCCR xn is reloaded with 0xFFFF_FFFF.)                                                          |
|               | 000 All timers reload with base count.                                                                                                                               |
|               | 001 Timers 1 and 2 reload with base count, timer 0 rolls over (reloads with 0xFFFF_FFFF).                                                                            |
|               | 010 Timers 0 and 2 reload with base count, timer 1 rolls over (reloads with 0xFFFF_FFFF).                                                                            |
|               | 011 Timer 2 reloads with base count, timers 0 and 1 roll over (reload with 0xFFFF_FFFF).                                                                             |
|               | 100 Timers 0 and 1 reload with base count, timer 2 rolls over (reloads with 0xFFFF_FFFF).                                                                            |
|               | 101 Timer 1 reloads with base count, timers 0 and 2 roll over (reload with 0xFFFF_FFFF).                                                                             |
|               | 110 Timer 0 reloads with base count, timers 1 and 2 roll over (reload with 0xFFFF_FFFF).                                                                             |
|               | 111 Timers 0, 1, and 2 roll over (reload with 0xFFFF_FFFF).                                                                                                          |
| 8–14<br>-     | This field is reserved. Reserved                                                                                                                                     |
| 15<br>RTM     | Real time mode. Specifies the clock source for the PIC timers.                                                                                                       |
|               | O Timer clock frequency is a ratio of the frequency of the CCB clock as determined by the CLKR field.  This is the default value.                                    |
|               | 1 The RTC signal is used to clock the PIC timers. If this bit is set, the CLKR field has no meaning.                                                                 |
| 16–21<br>-    | This field is reserved. Reserved                                                                                                                                     |
| 22–23         | Clock ratio. Specifies the ratio of the timer frequency to the CCB clock. The following are supported:                                                               |
| CLKR          | 00 Default. Divide by 8                                                                                                                                              |
|               | 01 Divide by 16                                                                                                                                                      |
|               | 10 Divide by 32                                                                                                                                                      |
|               | 11 Divide by 64                                                                                                                                                      |
| 24–28         | This field is reserved.                                                                                                                                              |
| -             | Reserved                                                                                                                                                             |
| 29–31<br>CASC | Cascade timers. Specifies the output of particular global timers as input to others.                                                                                 |
|               | 000 Default. Timers not cascaded                                                                                                                                     |
|               | 001 Cascade timers 0 and 1                                                                                                                                           |
|               | 010 Cascade timers 1 and 2                                                                                                                                           |
|               | 011 Cascade timers 0, 1, and 2                                                                                                                                       |
|               | 100 Cascade timers 2 and 3                                                                                                                                           |
|               | 101 Cascade timers 0 and 1; timers 2 and 3                                                                                                                           |
|               | 110 Cascade timers 1, 2, and 3                                                                                                                                       |
|               | 111 Cascade timers 0, 1, 2, and 3                                                                                                                                    |

1. Counting down from 59 through 0 requires 60 ticks.

## 9.3.20 External interrupt summary register (PIC\_ERQSR)

### NOTE

ERQSR fields report only the current logic level of IRQ0-IRQ6 pins. These fields were designed to work with level-sensitive interrupts; values returned for edge-sensitive interrupts may be unreliable.





### PIC\_ERQSR field descriptions

| Field        | Description                                                                             |
|--------------|-----------------------------------------------------------------------------------------|
| 0–6<br>EINTn | External interrupts signal 0-6 status. Bit 0 represents EINT0. Bit 6 represents EINT 6. |
|              | 0 The corresponding external interrupt signal is at a low logic level .                 |
|              | 1 The corresponding external interrupt signal is at a high logic level .                |
| 7–31<br>-    | This field is reserved. Reserved                                                        |

# 9.3.21 IRQ\_OUT\_B summary register 0 (PIC\_IRQSR0)

Address: 4\_0000h base + 1310h offset = 4\_1310h



### PIC\_IRQSR0 field descriptions

| Field         | Description                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                        |
| 20–26<br>EXTn | External interrupts 0-6. Each bit corresponds to a unique interrupt according to the following:  Bit Interrupt  20 IRQ0 |

Table continues on the next page...

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## PIC\_IRQSR0 field descriptions (continued)

| Field      | Description                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------|
|            | 21 IRQ1                                                                                                          |
|            |                                                                                                                  |
|            | 26 IRQ6                                                                                                          |
|            | 0 The corresponding interrupt is not active or not routed to IRQ_OUT_B.                                          |
|            | 1 The corresponding interrupt is active and routed to IRQ_OUT_B (if the corresponding <i>x</i> IDRn[EP] is set). |
| 27–31<br>- | This field is reserved. Reserved                                                                                 |

# 9.3.22 IRQ\_OUT\_B summary register 1 (PIC\_IRQSR1)

Address: 4\_0000h base + 1320h offset = 4\_1320h



### PIC\_IRQSR1 field descriptions

| Field        | Description                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>INTn | Internal interrupts 0-31 status. Bit 0 represents INT0. Bit 31 represents INT31.                                             |
|              | 0 The corresponding interrupt is not active or not routed to IRQ_OUT_B.                                                      |
|              | 1 The corresponding interrupt is active and is routed to IRQ_OUT_B (that is, if the corresponding <i>x</i> IDRn[EP] is set). |

# 9.3.23 IRQ\_OUT\_B summary register 2 (PIC\_IRQSR2)

Address: 4\_0000h base + 1324h offset = 4\_1324h



### PIC\_IRQSR2 field descriptions

| Field        | Description                                                                        |
|--------------|------------------------------------------------------------------------------------|
| 0–31<br>INTn | Internal interrupts 32-63 status. Bit 0 represents INT32. Bit 31 represents INT63. |

## PIC\_IRQSR2 field descriptions (continued)

| Field | Description                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------|
|       | 0 The corresponding interrupt is not active or not routed to IRQ_OUT_B.                                     |
|       | 1 The corresponding interrupt is active and is routed to IRQ_OUT_B, if the corresponding x IDRn[EP] is set. |

# 9.3.24 Critical interrupt summary register 0 (PIC\_CISR0)

Address: 4\_0000h base + 1330h offset = 4\_1330h



### PIC\_CISR0 field descriptions

| Field         | Description                                                                                                                                             |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                        |
| 20–26<br>EXTn | External interrupts 0-6. Bit 20 represents IRQ0. Bit 26 represents IRQ6.  O The corresponding interrupt is not active or not routed to cint 0 or cint1. |
|               | 1 The corresponding interrupt is active and is routed to cint 0 or cint1 (if the corresponding <i>x</i> IDRn[CI] is set).                               |
| 27–31<br>-    | This field is reserved. Reserved                                                                                                                        |

# 9.3.25 Critical interrupt summary register 1 (PIC\_CISR1)

Address: 4\_0000h base + 1340h offset = 4\_1340h



### PIC\_CISR1 field descriptions

| Field        | Description                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>INTn | Internal interrupts 0-31. Bit 0 represents INT0. Bit 31 represents INT31.                                                     |
|              | 0 Corresponding interrupt is not active or not routed to cint 0 or cint1.                                                     |
|              | 1 The corresponding interrupt is active and is routed to the cint 0 or cint1 (if the corresponding <i>x</i> IDRn[CI] is set). |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 9.3.26 Critical interrupt summary register 2 (PIC\_CISR2)

Address: 4\_0000h base + 1344h offset = 4\_1344h



### PIC\_CISR2 field descriptions

| Field        | Description                                                                                                                                                                                                              |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>INTn | Internal interrupts 32-63. Bit 0 represents INT32. Bit 31 represents INT63.                                                                                                                                              |
|              | <ul> <li>Corresponding interrupt is not active or not routed to cint 0 or cint1.</li> <li>The corresponding interrupt is active and is routed to the cint 0 or cint1, if the corresponding x IDRn[CI] is set.</li> </ul> |

# 9.3.27 Performance monitor n mask register 0 (PIC\_PMnMR0)

Each PM *n* MR0 register is matched with a PM *n* MR1 and a PM *n* MR2 register. Because each unreserved bit in the 96-bit vector (PM *n* MR0/1/2) specifies a different interrupt, only one bit in the 96-bit vector can be unmasked at a time. Unmasking more than 1 bit per set is considered a programming error and results in unpredictable behavior.

Address:  $4_{0000h}$  base + 1350h offset + (32d × i), where i=0d to 3d



## PIC\_PMnMR0 field descriptions

| Field       | Description                                                                                           |
|-------------|-------------------------------------------------------------------------------------------------------|
| 0-7<br>MShI | Shared message signaled interrupts 0-7                                                                |
|             | 0 The corresponding interrupt source generates a performance monitor event when the interrupt occurs. |
|             | 1 The corresponding interrupt does not generate a performance monitor event.                          |
| 8–11<br>IPI | Interprocessor interrupts 0-3                                                                         |
|             | 0 The corresponding interrupt source generates a performance monitor event when the interrupt occurs. |
|             | 1 The corresponding interrupt does not generate a performance monitor event.                          |

### PIC\_PMnMR0 field descriptions (continued)

| Field          | Description                                                                                                                                               |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12–15<br>TIMER | Timer interrupts 0-3 (Group A and Group B: Each bit represents an OR of the event for the correspondingly numbered timer in Group A and that in Group B). |
|                | 0 The corresponding interrupt source generates a performance monitor event when the interrupt occurs.                                                     |
|                | 1 The corresponding interrupt does not generate a performance monitor event.                                                                              |
| 16–19          | Message interrupts 0-7                                                                                                                                    |
| MSG            | Bit 0 is used for MSG0 and MSG4                                                                                                                           |
|                | Bit 1 is used for MSG1 and MSG5                                                                                                                           |
|                | Bit 2 is used for MSG2 and MSG6                                                                                                                           |
|                | Bit 3 is used for MSG3 and MSG7                                                                                                                           |
|                | 0 The corresponding interrupt source generates a performance monitor event when the interrupt occurs.                                                     |
|                | 1 The corresponding interrupt does not generate a performance monitor event.                                                                              |
| 20–26<br>EXT   | External interrupts IRQ[0:6]                                                                                                                              |
|                | 0 The corresponding interrupt source generates a performance monitor event when the interrupt occurs.                                                     |
|                | 1 The corresponding interrupt does not generate a performance monitor event.                                                                              |
| 27–31<br>-     | This field is reserved. Reserved                                                                                                                          |

# 9.3.28 Performance monitor n mask register 1 (PIC\_PMnMR1)

Address:  $4_{0000h}$  base + 1360h offset + (32d × i), where i=0d to 3d



### PIC\_PMnMR1 field descriptions

| Field       | Description                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>INT | Internal interrupts 0-31  The corresponding interrupt source generates a performance monitor event when the interrupt occurs. |
|             | 1 The corresponding interrupt does not generate a performance monitor event.                                                  |

## 9.3.29 Performance monitor n mask register 2 (PIC\_PMnMR2)

Address:  $4_{0000h}$  base + 1364h offset + (32d × i), where i=0d to 3d



#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### PIC\_PMnMR2 field descriptions

| Field       | Description                                                                                                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>INT | Internal interrupts 32-63                                                                                                                                                                                   |
|             | <ul> <li>The corresponding interrupt source generates a performance monitor event when the interrupt occurs.</li> <li>The corresponding interrupt does not generate a performance monitor event.</li> </ul> |

## 9.3.30 Message register n (PIC\_MSGRn)

The message registers (MSGR0-MSGR 7) can contain a 32-bit message. For (MSGR4-MSGR7), see Message register n (PIC\_MSGRan)



### PIC\_MSGRn field descriptions

| Field       | Description                                |
|-------------|--------------------------------------------|
| 0–31<br>MSG | Message. Contains the 32-bit message data. |

## 9.3.31 Message enable register (PIC\_MER)

The MER contains the enable bits for each message register. The enable bit must be set to enable interrupt generation when the corresponding message register is written.

When bits in MER are set to mask message interrupts, an interrupt is not generated if the message register is written while it is masked in MER and the MER bit is then cleared. To mask the interrupt without loss, set MIVPR *n* [MSK] (See Messaging interrupt n (MSGn) vector/priority register (PIC\_MIVPR*n*)). MER should be set to 0x0000\_000F at reset and then left unchanged during normal operation.





### PIC\_MER field descriptions

| Field       | Description                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>-   | This field is reserved. Reserved                                                                                                                                                |
| 28–31<br>En | Enable 3-enable 0.  Used to enable interrupt generation for MSGRn (where <i>n</i> = 0-3).  1 Interrupt generation for MSGRn enabled.  1 Interrupt generation for MSGRn enabled. |

# 9.3.32 Message status register (PIC\_MSR)

The message status register (MSR) contains status bits for each message register. A status bit is set when the corresponding messaging interrupt is active. Writing a 1 to a status bit clears the corresponding message interrupt and the status bit.

Address: 4\_0000h base + 1510h offset = 4\_1510h



### PIC\_MSR field descriptions

| Field       | Description                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------|
| 0–27<br>-   | This field is reserved. Reserved                                                                    |
| 28–31<br>Sn | Status 3-status 0 . Reports status of messaging interrupt <i>n</i> . Writing a 1 clears this field. |
|             | 0 Messaging interrupt <i>n</i> is not active.                                                       |
|             | 1 Messaging interrupt <i>n</i> is active.                                                           |

## 9.3.33 Shared message signaled interrupt register n (PIC\_MSIRn)

The eight MSIRs indicate which of the up to 32 interrupt sources sharing the message register have pending interrupts. These registers are cleared when read. A write to these registers has no effect.

#### NOTE

After soft reset, read the MSIRs to ensure that any interrupts previously pending are cleared.

#### PIC memory map/register definition





### PIC\_MSIRn field descriptions

| Field       | Description                               |
|-------------|-------------------------------------------|
| 0–31<br>SHn | Message sharer n has a pending interrupt. |

# 9.3.34 Shared message signaled interrupt status register (PIC\_MSISR)

MSISR contains the status bits for the shared message signaled interrupts. A status bit is set when the corresponding MSIR has an active interrupt. The status bit is 0 if all the corresponding shared interrupt sources are cleared for that MSIR.

Address: 4\_0000h base + 1720h offset = 4\_1720h



### PIC\_MSISR field descriptions

| Field       | Description                                                         |
|-------------|---------------------------------------------------------------------|
| 0–23        | This field is reserved. Reserved                                    |
| 24–31<br>Sn | Status n.  0 MSIRn is not active.  1 MSIRn has an active interrupt. |

# 9.3.35 Shared message signaled interrupt index register (PIC\_MSIIR)

MSIIR provides the mechanism for setting an interrupt in the MSIRs. When MSIIR is written, MSIIR[SRS] selects the register in which an interrupt bit is to be set; MSIIR[IBS] selects the shared interrupt field in the selected MSIR register to be set. MSIIR is primarily intended to support PCI Express MSIs.





### PIC\_MSIIR field descriptions

| Field     | Description                                                      |
|-----------|------------------------------------------------------------------|
| 0–2       | Shared interrupt register select. Selects the MSIR to be written |
| SRS       | Example settings:                                                |
|           | 000 MSIR 0                                                       |
|           | 001 MSIR 1                                                       |
|           | 010 MSIR 2                                                       |
|           |                                                                  |
|           | 111 MSIR 7                                                       |
| 3–7       | Interrupt bit select-Selects the bit to set in the MSIR          |
| IBS       | Example settings:                                                |
|           | 00000 Set field SH0 (bit 31)                                     |
|           | 00001 Set field SH1 (bit 30)                                     |
|           | 00010 Set field SH2 (bit 29)                                     |
|           |                                                                  |
|           | 11111 Set field SH31 (bit 0)                                     |
| 8–31<br>- | This field is reserved. Reserved                                 |

# 9.3.36 Global timer n current count register group B (PIC\_GTCCRBn)

The GTCCRs contain the current count for each of the four PIC timers in each of the two groups.



### PIC\_GTCCRBn field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>TOG | Toggle. Toggles when the current count decrements to zero. Cleared when GTBCR xn [CI] goes from 1 to 0.                                                                                                                                                                                                                                                                                                                                                                                         |
| COUNT    | Current count. Decremented while GTBCR $xn$ [CI] is zero. When the timer count reaches zero, an interrupt is generated (provided it is not masked), the toggle bit is inverted, and the count is reloaded. For non-cascaded timers, the reload value is the contents of the corresponding GTBCR $xn$ . Cascaded timers are reloaded with either all ones, or the GTBCR $xn$ contents, depending on the value of TCRn[ROVR]. See Timer control register group n (PIC_TCR $n$ ) for more details. |

Reset

# 9.3.37 Global timer n base count register group B (PIC\_GTBCRBn)

The GTBCRs contain the base counts for each of the four PIC timers in each of the two groups. This value is reloaded into the corresponding GTCCR xn when the current count reaches zero. Note that when zero is written to the base count field, (and GTCCR xn [CI] = 0), the timer generates an interrupt on every timer cycle.





### PIC\_GTBCRBn field descriptions

| Field            | Description                                                                                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>CI          | Count inhibit. Always set following reset  0 Counting enabled                                                                                                                                                                                                                     |
|                  | 1 Counting inhibited                                                                                                                                                                                                                                                              |
| 1–31<br>BASE_CNT | Base count. When CI transitions from 1 to 0, this value is copied into the corresponding GTCCR $xn$ and the toggle bit is cleared. If CI is already cleared (counting is in progress), the base count is copied to the GTCCR $xn$ at the next zero crossing of the current count. |

# 9.3.38 Global timer n vector/priority register group B (PIC\_GTVPRBn)

The GTVPRs contain the interrupt vector and the interrupt priority values for the timers. They also contain the mask and activity fields for all the timers. See Flow of interrupt control for information on IPR and ISR.



### PIC\_GTVPRBn field descriptions

| Field             | Description                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MSK          | Mask. Mask interrupts to int from this source.                                                                                                                                                                          |
|                   | 0 An interrupt request is generated if the corresponding IPR bit is set.                                                                                                                                                |
|                   | 1 Further interrupts from this source are disabled.                                                                                                                                                                     |
| 1<br>A            | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set.                                                                       |
|                   | No current interrupt activity associated with this source.                                                                                                                                                              |
|                   | 1 The interrupt field for this source is set in the IPR or ISR.                                                                                                                                                         |
| 2–11<br>-         | This field is reserved. Reserved                                                                                                                                                                                        |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |

## 9.3.39 Global timer n destination register group B (PIC\_GTDRBn)

The GTDR *xn* registers control the destination (core) to which each timer's interrupt is directed. Note that GTDR *xn* bits can be set independently of each other and that either P1 or P0 or both can be set for this type of interrupt.



### PIC\_GTDRBn field descriptions

| Field     | Description                                                                                                                                                                                     |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29<br>- | This field is reserved. Reserved                                                                                                                                                                |
| 30<br>P1  | Processor core 1. This interrupt is multicasting, so both P0 and P1 can be set.  NOTE: Reserved in single-processor implementations.                                                            |
|           | Processor core 1 does not receive this interrupt     Directs the timer interrupt to processor core 1                                                                                            |
| 31<br>P0  | Processor core 0 . Default destination after PIC is reset. Both P0 and P1 can be set.  0 Processor core 0 does not receive this interrupt.  1 Directs the timer interrupt to processor core 0 . |

## 9.3.40 Message register n (PIC\_MSGRan)

The message registers (MSGR0-MSGR 7) can contain a 32-bit message. For (MSGR0-MSGR3), see Message register n (PIC\_MSGRn)



### PIC\_MSGRan field descriptions

| Field       | Description                                |
|-------------|--------------------------------------------|
| 0–31<br>MSG | Message. Contains the 32-bit message data. |

## 9.3.41 Message enable register (PIC\_MERa)

The MER contains the enable bits for each message register. The enable bit must be set to enable interrupt generation when the corresponding message register is written.

When bits in MER are set to mask message interrupts, an interrupt is not generated if the message register is written while it is masked in MER and the MER bit is then cleared. To mask the interrupt without loss, set MIVPR *n* [MSK]. (See Messaging interrupt n (MSGn) vector/priority register (PIC\_MIVPR*n*).) MER should be set to 0x0000\_000F at reset and then left unchanged during normal operation.

Address: 4\_0000h base + 2500h offset = 4\_2500h



### PIC\_MERa field descriptions

| Field       | Description                                                                                                                                                                      |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>-   | This field is reserved. Reserved                                                                                                                                                 |
| 28–31<br>En | Enable 3-enable 0.  Used to enable interrupt generation for MSGRn (where <i>n</i> = 0-3).  1 Interrupt generation for MSGRn disabled.  1 Interrupt generation for MSGRn enabled. |

## 9.3.42 Message status register (PIC\_MSRa)

The message status register (MSR) contains status bits for each message register. A status bit is set when the corresponding messaging interrupt is active. Writing a 1 to a status bit clears the corresponding message interrupt and the status bit.





### PIC\_MSRa field descriptions

| Field       | Description                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------|
| 0–27<br>-   | This field is reserved. Reserved                                                                    |
| 28–31<br>Sn | Status 3-status 0 . Reports status of messaging interrupt <i>n</i> . Writing a 1 clears this field. |
|             | 0 Messaging interrupt <i>n</i> is not active.                                                       |
|             | 1 Messaging interrupt <i>n</i> is active.                                                           |

# 9.3.43 External interrupt n (IRQn) vector/priority register (PIC\_EIVPRn)

The EIVPRs contain polarity and sense fields for the external interrupts, that is, those caused by the assertion of any of IRQ[0:6]. See Flow of interrupt control for information on IPR and ISR.

Address:  $4_{0000h}$  base +  $1_{0000h}$  offset +  $(32d \times i)$ , where i=0d to 6d



### PIC memory map/register definition

## PIC\_EIVPRn field descriptions

| Field             | Description                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MSK          | Mask. Mask interrupts from this source. MSK affects only interrupts routed to int.                                                                                                                                      |
|                   | 0 An interrupt request is generated if the corresponding IPR bit is set.                                                                                                                                                |
|                   | 1 Further interrupts from this source are disabled.                                                                                                                                                                     |
| 1<br>A            | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set. Affects only interrupts routed to int.                                |
|                   | 0 No current interrupt activity associated with this source.                                                                                                                                                            |
|                   | 1 The interrupt field for this source is set in the IPR or ISR.                                                                                                                                                         |
| 2–7<br>-          | This field is reserved. Reserved                                                                                                                                                                                        |
| 8<br>P            | Polarity. Specifies the polarity for the external interrupt.                                                                                                                                                            |
|                   | 0 Polarity is active-low or negative edge-triggered.                                                                                                                                                                    |
|                   | 1 Polarity is active-high or positive edge-triggered.                                                                                                                                                                   |
| 9<br>S            | Sense. Specifies the sense for external interrupts.                                                                                                                                                                     |
| J                 | <b>NOTE:</b> If an IRQ <i>n</i> signal is used to receive INT <i>x</i> signals from one of the PCI Express ports as a root complex, S must be set to be level-sensitive.                                                |
|                   | 0 The external interrupt is edge sensitive.                                                                                                                                                                             |
|                   | 1 The external interrupt is level sensitive. This setting must be used to direct the interrupt to IRQ_OUT_B or cint.                                                                                                    |
| 10–11<br>-        | This field is reserved. Reserved                                                                                                                                                                                        |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |

# 9.3.44 External interrupt n (IRQn) destination register (PIC\_EIDRn)

The EIDRs control the destination of external interrupts caused by the assertion of any of IRQ[0:6]. Only one destination bit may be set; otherwise, behavior is undefined.

Address:  $4_{0000h}$  base +  $1_{0010h}$  offset + (32d × i), where i=0d to 6d



### PIC\_EIDRn field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                    |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EP   | External signal. Allows interrupt to be serviced externally. EP should be set only for level-sensitive external interrupts (EIVPRn[S]= 1). Setting for edge-sensitive does not provide reliable interrupt response.                                                                            |
|           | <ul><li>0 Interrupt is not routed to IRQ_OUT_B.</li><li>1 Interrupt is routed to IRQ_OUT_B for external service.</li></ul>                                                                                                                                                                     |
| 1<br>CI0  | Critical interrupt 0. Cin fields should be set only for level-sensitive external interrupts (EIVPRn[S]= 1). Setting them for edge-sensitive does not provide reliable interrupt response.                                                                                                      |
|           | <ul> <li>Processor core 0 does not receive this interrupt.</li> <li>Directs the external interrupt to processor core 0 by causing the <i>cint0</i> output signal from the PIC to assert. See Interrupts to the e500 processor core .</li> </ul>                                                |
| 2<br>Cl1  | Critical interrupt 1. Cin fields should be set only for level-sensitive external interrupts (EIVPRn[S]= 1). Setting them for edge-sensitive does not provide reliable interrupt response. Reserved in single-processor implementations.                                                        |
|           | <ul> <li>Processor core 1 does not receive this interrupt.</li> <li>Directs the external interrupt to processor core 1 by causing the <i>cint1</i> output signal from the PIC to assert. See Interrupts to the e500 processor core .</li> </ul>                                                |
| 3–29<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                               |
| 30<br>P1  | Processor core 1. Indicates whether processor core 1 receives the interrupt through <i>int</i> .  NOTE: Reserved in single-processor implementations.  0 Processor core 1 does not receive this interrupt.  1 Directs the interrupt to processor core 1 through the assertion of <i>int</i> 1. |
| 31<br>P0  | Processor core 0 . Indicates whether processor core 0 receives the interrupt.  The default destination is for processor core 0 to receive this external interrupt after the PIC is reset.                                                                                                      |

Table continues on the next page...

### PIC\_EIDRn field descriptions (continued)

| Field | Description                                                                |
|-------|----------------------------------------------------------------------------|
|       | Processor core 0 does not receive this interrupt.                          |
|       | 1 Directs the interrupt to processor core 0 through the assertion of int0. |

# 9.3.45 Internal interrupt n vector/priority register (PIC\_IIVPRn)

The IIVPRs have the same fields and format as the GTVPRs, except that they apply to the internal interrupt sources listed in Table 9-4. These interrupts are all level-sensitive. See Flow of interrupt control for information on IPR and ISR.

### NOTE

Because all internal interrupts are active-high, clearing the polarity field, IIVPR n [P], disables that interrupt. Care should be taken to ensure this field is set during initialization and that it is not inadvertently corrupted when loading or reloading IIVPRs with priority, mask, or vector data.

Address:  $4_{0000h}$  base +  $1_{0200h}$  offset +  $(32d \times i)$ , where i=0d to 63d



### PIC\_IIVPRn field descriptions

| Field    | Description                                                                                                                                                                              |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MSK | Mask. Mask interrupts from this source. MSK affects only interrupts routed to int.                                                                                                       |
|          | 0 An interrupt request is generated if the corresponding IPR bit is set.                                                                                                                 |
|          | 1 Further interrupts from this source are disabled.                                                                                                                                      |
| 1<br>A   | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set. Affects only interrupts routed to int. |
|          | No current interrupt activity associated with this source.                                                                                                                               |
|          | 1 The interrupt field for this source is set in the IPR or ISR.                                                                                                                          |
| 2–7<br>- | This field is reserved. Reserved                                                                                                                                                         |

Table continues on the next page...

## PIC\_IIVPRn field descriptions (continued)

| Field             | Description                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8<br>P            | Polarity. Specifies the polarity for the internal interrupt. Note: Because all internal interrupts are active-high, clearing this bit disables the interrupt.                                                           |
|                   | 0 Interrupt polarity is active-low. This value disables the interrupt.                                                                                                                                                  |
|                   | 1 Interrupt polarity is active-high.                                                                                                                                                                                    |
| 9–11<br>-         | This field is reserved. Reserved                                                                                                                                                                                        |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |

## 9.3.46 Internal interrupt n destination register (PIC\_IIDRn)

The IIDRs have the same fields and format as EIVDRs, except that they apply to the internal interrupt sources listed in Table 9-4. Only one destination bit may be set; otherwise, behavior is undefined.

Address:  $4_{0000h}$  base +  $1_{0210h}$  offset +  $(32d \times i)$ , where i=0d to 63d



### PIC\_IIDRn field descriptions

| Field    | Description                                                                                                                          |
|----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EP  | External signal. Allows internal interrupt to be serviced externally.                                                                |
|          | 0 Interrupt is not routed to IRQ_OUT_B.                                                                                              |
|          | 1 Interrupt is routed to IRQ_OUT_B for external service.                                                                             |
| 1<br>CIO | Critical interrupt 0. See Interrupts to the e500 processor core for more information.                                                |
|          | 0 Processor core 0 does not receive this interrupt.                                                                                  |
|          | 1 Directs the internal interrupt to processor core 0 by causing the <i>cint0</i> output signal from the PIC to assert.               |
| 2<br>Cl1 | Critical interrupt 1. See Interrupts to the e500 processor core, for more information. Reserved in single-processor implementations. |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### PIC\_IIDRn field descriptions (continued)

| Field    | Description                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------|
|          | Processor core 1 does not receive this interrupt.                                                                      |
|          | 1 Directs the internal interrupt to processor core 1 by causing the <i>cint1</i> output signal from the PIC to assert. |
| 3–29     | This field is reserved. Reserved                                                                                       |
| 30<br>P1 | Processor core 1. Indicates whether processor core 1 receives the interrupt through int.                               |
|          | NOTE: Reserved in single-processor implementations.                                                                    |
|          | Processor core 1 does not receive this interrupt.                                                                      |
|          | 1 Directs the interrupt to processor core 1 through the assertion of <i>int1</i> .                                     |
| 31       | Processor core 0 . Indicates whether processor core 0 receives the interrupt.                                          |
| P0       | The default destination is for processor core 0 to receive this external interrupt after the PIC is reset.             |
|          | 0 Processor core 0 does not receive this interrupt.                                                                    |
|          | 1 Directs the interrupt to processor core 0 through the assertion of int0.                                             |

# 9.3.47 Messaging interrupt n (MSGn) vector/priority register (PIC\_MIVPRn)

The MIVPRs have the same fields and format as the GTVPRs, except they apply to messaging interrupts. See Flow of interrupt control for information on IPR and ISR.





### PIC\_MIVPRn field descriptions

| Field    | Description                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MSK | Mask. Mask interrupts from this source. MSK affects only interrupts routed to int.                                                                    |
|          | <ul> <li>An interrupt request is generated if the corresponding IPR bit is set.</li> <li>Further interrupts from this source are disabled.</li> </ul> |

Table continues on the next page...

## PIC\_MIVPRn field descriptions (continued)

| Field             | Description                                                                                                                                                                                                         |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>A            | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set. Affects only interrupts routed to int.                            |
|                   | <ul><li>No current interrupt activity associated with this source.</li><li>The interrupt field for this source is set in the IPR or ISR.</li></ul>                                                                  |
| 2–11              | This field is reserved. Reserved                                                                                                                                                                                    |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int. |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |

# 9.3.48 Messaging interrupt n (MSGn) destination register (PIC\_MIDRn)

The messaging interrupt destination registers (MIDRs) control the destination for the messaging interrupts. Only one destination bit may be set; otherwise, behavior is undefined.

Address:  $4_{0000h}$  base +  $1_{1610h}$  offset +  $(32d \times i)$ , where i=0d to 7d



PIC\_MIDRn field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                    |  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–29     | This field is reserved. Reserved                                                                                                                                                                                                                                                               |  |
| 30<br>P1 | Processor core 1. Indicates whether processor core 1 receives the interrupt through <i>int</i> .  NOTE: Reserved in single-processor implementations.  O Processor core 1 does not receive this interrupt.  1 Directs the interrupt to processor core 1 through the assertion of <i>int1</i> . |  |
| 31<br>P0 | Processor core 0 . Indicates whether processor core 0 receives the interrupt.  The default destination is for processor core 0 to receive this external interrupt after the PIC is reset.                                                                                                      |  |

Table continues on the next page...

### PIC\_MIDRn field descriptions (continued)

| Field | Description                                                                        |
|-------|------------------------------------------------------------------------------------|
|       | Processor core 0 does not receive this interrupt.                                  |
|       | 1 Directs the interrupt to processor core 0 through the assertion of <i>int0</i> . |

# 9.3.49 Shared message signaled interrupt vector/priority register n (PIC\_MSIVPRn)

The MSIVPRs have the same fields and format as the GTVPRs. See Flow of interrupt control for information on IPR and ISR.





### PIC\_MSIVPRn field descriptions

| Field             | Description                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MSK          | Mask. Mask interrupts from this source. MSK affects only interrupts routed to int.                                                                                                                                      |
|                   | 0 An interrupt request is generated if the corresponding IPR bit is set.                                                                                                                                                |
|                   | 1 Further interrupts from this source are disabled.                                                                                                                                                                     |
| 1<br>A            | Activity. Indicates an interrupt has been requested or is in service. The VECTOR and PRIORITY values should not be changed while this bit is set. Affects only interrupts routed to int.                                |
|                   | 0 No current interrupt activity associated with this source.                                                                                                                                                            |
|                   | 1 The interrupt field for this source is set in the IPR or ISR.                                                                                                                                                         |
| 2–11<br>-         | This field is reserved. Reserved                                                                                                                                                                                        |
| 12–15<br>PRIORITY | Priority. Specifies the interrupt priority. The lowest priority is 0 and the highest priority is 15. A priority level of 0 inhibits signaling of this interrupt to the core. Affects only interrupts routed to int.     |
| 16–31<br>VECTOR   | Vector (Affects only interrupts routed to int). Contains the value returned when IACK is read and this interrupt resides in the corresponding interrupt request register (IRR) for that core, as shown in Figure 9-321. |

# 9.3.50 Shared message signaled interrupt destination register n (PIC\_MSIDRn)

The MSIDRs contain the destination bits for the shared message signaled interrupt. A shared message signaled interrupt can be directed to one of the processors by setting the appropriate bit in the shared message signaled interrupt destination register. Only one of the bits corresponding to destination processors may be set. The behavior if more than one bit is set is not defined. This register also contains the external pin and critical interrupt field s that can be programmed to direct the interrupt to the external pin or critical interrupt pin of the processor, respectively.



<sup>\*</sup> Notes:

### PIC\_MSIDRn field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                       |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                  |
| 30<br>P1  | Processor core 1. Indicates whether processor core 1 receives the interrupt through <i>int</i> .  NOTE: Reserved in single-processor implementations.  0 Processor core 1 does not receive this interrupt.  1 Directs the interrupt to processor core 1 through the assertion of <i>int1</i> .                                                    |
| 31<br>P0  | Processor core 0 . Indicates whether processor core 0 receives the interrupt.  The default destination is for processor core 0 to receive this shared message signaled interrupt after the PIC is reset.  0 Processor core 0 does not receive this interrupt.  1 Directs the interrupt to processor core 0 through the assertion of <i>int0</i> . |

<sup>•</sup> P1 field: Reserved in single-processor implementations.

# 9.3.51 Processor core 0 interprocessor n dispatch register (PIC\_IPIDR\_CPU0n)

The figure below shows the four IPIDRs, one for each interprocessor interrupt channel. Writing to an IPIDR with a bit set causes a self interrupt for a single-core device. Because external bus masters can write to these registers, this feature can serve as a doorbell type interrupt.



PIC\_IPIDR\_CPU0n field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                           |
| 30<br>P1  | Processor core 1. Specifies if processor core 1 receives the interrupt. This interrupt is multicasting, so both P0 and P1 can be set.  NOTE: Reserved in single-processor implementations.  O Processor core 1 does not receive the interrupt  1 Directs the interrupt to processor core 1 |
| 31<br>P0  | Processor core 0 . Determines if processor core 0 receives the interrupt.  O Processor core 0 does not receive the interrupt.  Directs the interrupt to processor core 0.                                                                                                                  |

# 9.3.52 Processor core current task priority register 0 Processor core (PIC\_CTPR\_CPU0)

There is one CTPR per processor core on this device.

#### NOTE

CTPR has meaning only for interrupts routed to int.

Software must write the priority of the current processor core task in the CTPR for each core. The PIC uses this value for comparison with the priority of incoming interrupts. Given several concurrent incoming interrupts, the highest priority interrupt is asserted to that core if the following apply:

- The interrupt is not masked.
- The priority of the interrupt is higher than the values in the corresponding CTPR[TASKP] and ISR.





### PIC\_CTPR\_CPU0 field descriptions

| Field          |                             | Description                                                                                                                                                       |  |
|----------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–27<br>-      | This field is r<br>Reserved | reserved.                                                                                                                                                         |  |
| 28–31<br>TASKP |                             | Task priority. Indicates the threshold that individual interrupt priorities must exceed for the interrupt request to be serviced.                                 |  |
|                | 0000-1111                   | xVPRn[PRIORITY] must exceed this value for the interrupt request to be serviced. Note the following special cases:                                                |  |
|                | 0000                        | Lowest priority. All interrupts except those whose priority are 0 can be serviced.                                                                                |  |
|                | 1111                        | Highest priority. No interrupts are signaled to that processor core. Hardware selects this value on a device hard reset or when the corresponding PIR[Pn] is set. |  |

## 9.3.53 Processor core 0 who am I register (PIC\_WHOAMI\_CPU0)

The processor core WHOAMI *n* register can be read by a processor core to determine its physical connection to the PIC. The value returned when reading this register may be used to determine the value for the destination masks used for dispatching interrupts.

Address: 4\_0000h base + 2\_0090h offset = 6\_0090h



### PIC\_WHOAMI\_CPU0 field descriptions

| Field | Description                                                                              |
|-------|------------------------------------------------------------------------------------------|
| 0–26  | This field is reserved.                                                                  |
| -     | Reserved                                                                                 |
| 27–31 | Returns the ID of the processor core reading this register. Does not always return zero. |
| ID    |                                                                                          |
|       | 0_0000 Processor core 0                                                                  |
|       | 0_0001 Processor core 1. (Value not supported in single-processor implementations.)      |
|       | 1_1111 All other devices                                                                 |

# 9.3.54 Processor core 0 interrupt acknowledge register (PIC\_IACK\_CPU0)

#### **NOTE**

IACK has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

In systems based on processors built on Power Architecture technology, the interrupt acknowledge function occurs as an explicit read operation to a memory-mapped interrupt acknowledge register (IACK). Each processor core has an IACK register assigned to it. Reading IACK returns the interrupt vector corresponding to the highest priority pending interrupt. Reading IACK also has the following side effects:

- The associated field in the corresponding interrupt pending register (IPR) is cleared for edge-sensitive interrupts. See Interrupts routed to *int*.
- The corresponding in-service register (ISR) is updated.
- The corresponding *int* output signal from the PIC is negated.

Reading IACK when no interrupt is pending returns the spurious vector value, as described in Spurious vector register (PIC\_SVR).

Address: 4\_0000h base + 2\_00A0h offset = 6\_00A0h



### PIC\_IACK\_CPU0 field descriptions

| Field           | Description                                               |
|-----------------|-----------------------------------------------------------|
| 0–15<br>-       | This field is reserved. Reserved                          |
| 16–31<br>VECTOR | Interrupt vector. Vector of the highest pending interrupt |

# 9.3.55 Processor core 0 end of interrupt register (PIC\_EOI\_CPU0)

#### NOTE

EOI has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

Each core is assigned an EOI register. Writing to EOI signals the end of processing for the highest-priority interrupt (routed to *int*) currently in service. It also updates the corresponding ISR *n* by retiring the highest priority interrupt. Data values written to EOI are ignored, and zero is assumed.





### PIC\_EOI\_CPU0 field descriptions

| Field             | Description                      |
|-------------------|----------------------------------|
| 0–27<br>-         | This field is reserved. Reserved |
| 28–31<br>EOI_CODE | 0000 (write only)                |

# 9.3.56 Processor core 1 interprocessor n dispatch register (PIC\_IPIDR\_CPU1*n*)

The figure below shows the four IPIDRs, one for each interprocessor interrupt channel. Writing to an IPIDR with a bit set causes a self interrupt for a single-core device. Because external bus masters can write to these registers, this feature can serve as a doorbell type interrupt.



PIC\_IPIDR\_CPU1n field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29     | This field is reserved. Reserved                                                                                                                                                                                                                                                           |
| 30<br>P1 | Processor core 1. Specifies if processor core 1 receives the interrupt. This interrupt is multicasting, so both P0 and P1 can be set.  NOTE: Reserved in single-processor implementations.  O Processor core 1 does not receive the interrupt  1 Directs the interrupt to processor core 1 |
| 31<br>P0 | Processor core 0 . Determines if processor core 0 receives the interrupt.  O Processor core 0 does not receive the interrupt.  Directs the interrupt to processor core 0.                                                                                                                  |

# 9.3.57 Processor core 1 current task priority register (PIC CTPR CPU1)

There is one CTPR per processor core on this device.

#### NOTE

CTPR has meaning only for interrupts routed to int.

Software must write the priority of the current processor core task in the CTPR for each core. The PIC uses this value for comparison with the priority of incoming interrupts. Given several concurrent incoming interrupts, the highest priority interrupt is asserted to that core if the following apply:

- The interrupt is not masked.
- The priority of the interrupt is higher than the values in the corresponding CTPR[TASKP] and ISR.





### PIC\_CTPR\_CPU1 field descriptions

| Field          | Description                                                                                                                                                       |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–27<br>-      | This field is reserved. Reserved                                                                                                                                  |  |
| 28–31<br>TASKP | Task priority. Indicates the threshold that individual interrupt priorities must exceed for the interrupt reque to be serviced.                                   |  |
|                | 0000-1111 xVPRn[PRIORITY] must exceed this value for the interrupt request to be serviced. Note the following special cases:                                      |  |
|                | Lowest priority. All interrupts except those whose priority are 0 can be serviced.                                                                                |  |
|                | Highest priority. No interrupts are signaled to that processor core. Hardware selects this value on a device hard reset or when the corresponding PIR[Pn] is set. |  |

## 9.3.58 Processor core 1 who am I register (PIC\_WHOAMI\_CPU1)

The processor core WHOAMI *n* register can be read by a processor core to determine its physical connection to the PIC. The value returned when reading this register may be used to determine the value for the destination masks used for dispatching interrupts.





### PIC\_WHOAMI\_CPU1 field descriptions

| Field | Description                                                                              |  |  |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0–26  | This field is reserved.                                                                  |  |  |  |  |  |  |  |
| -     | Reserved                                                                                 |  |  |  |  |  |  |  |
| 27–31 | Returns the ID of the processor core reading this register. Does not always return zero. |  |  |  |  |  |  |  |
| ID    |                                                                                          |  |  |  |  |  |  |  |
|       | 0_0000 Processor core 0                                                                  |  |  |  |  |  |  |  |
|       | 0_0001 Processor core 1. (Value not supported in single-processor implementations.)      |  |  |  |  |  |  |  |
|       | 1_1111 All other devices                                                                 |  |  |  |  |  |  |  |

# 9.3.59 Processor core 1 interrupt acknowledge register (PIC\_IACK\_CPU1)

#### **NOTE**

IACK has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

In systems based on processors built on Power Architecture technology, the interrupt acknowledge function occurs as an explicit read operation to a memory-mapped interrupt acknowledge register (IACK). Each processor core has an IACK register assigned to it. Reading IACK returns the interrupt vector corresponding to the highest priority pending interrupt. Reading IACK also has the following side effects:

- The associated field in the corresponding interrupt pending register (IPR) is cleared for edge-sensitive interrupts. See Interrupts routed to *int*.
- The corresponding in-service register (ISR) is updated.
- The corresponding *int* output signal from the PIC is negated.

Reading IACK when no interrupt is pending returns the spurious vector value, as described in Spurious vector register (PIC\_SVR).

Address: 4\_0000h base + 2\_10A0h offset = 6\_10A0h



### PIC\_IACK\_CPU1 field descriptions

| Field           | Description                                               |
|-----------------|-----------------------------------------------------------|
| 0–15<br>-       | This field is reserved. Reserved                          |
| 16–31<br>VECTOR | Interrupt vector. Vector of the highest pending interrupt |

# 9.3.60 Processor core 1 end of interrupt register (PIC\_EOI\_CPU1)

#### NOTE

EOI has meaning only for interrupts routed to *int* and should not be accessed for interrupts routed to *cint* or IRQ\_OUT\_B.

Each core is assigned an EOI register. Writing to EOI signals the end of processing for the highest-priority interrupt (routed to *int*) currently in service. It also updates the corresponding ISR *n* by retiring the highest priority interrupt. Data values written to EOI are ignored, and zero is assumed.





### PIC\_EOI\_CPU1 field descriptions

| Field             | Description                      |
|-------------------|----------------------------------|
| 0–27<br>-         | This field is reserved. Reserved |
| 28–31<br>EOI_CODE | 0000 (write only)                |

## 9.4 Functional description

This section is a functional description of the PIC.

## 9.4.1 Programming model considerations

## 9.4.1.1 Global registers

Although most PIC registers have one address, some are replicated for each e500 processor core in a multiprocessor device.

#### **Functional description**

For such registers, each core accesses its separate registers using the same address, the address decoding being sensitive to the processor core ID. A copy of the per-CPU registers is available to each e500 processor core at the same physical address, that is, in a private access address space that acts like an alias to a processor's own copy of the per-CPU registers. As shown in Figure 9-320, the ID of the core initiating the read/write transaction determines which processor's per-CPU registers to access. For more information, see Per-CPU (private access) registers.

### NOTE

Register fields designated as write-1-to-clear are cleared only by writing ones to them. Writing zeros to them has no effect.

## 9.4.1.2 Global timer registers

The two independent groups of global timer registers, group A and group B, are identical in their functionality, except that they appear at different locations within the PIC register map.

Note that each of the four timers within an x group have four individual configuration registers (GTCCRxn, GTBCRxn, GTVPRxn, and GTDRxn), but they are only shown once in this section. These two groups of timers cannot be cascaded together.

## 9.4.1.3 IRQ\_OUT\_B and critical interrupt summary registers

The summary registers indicate the specific interrupt sources routed to the IRQ\_OUT\_B or *cint0/cint1* PIC outputs.

Summary register bits are cleared when the corresponding interrupt that caused a bit to be set is negated.

Note that only level-sensitive interrupts can be routed to IRQ\_OUT\_B or *cint0* and *cint1*.

The IRQ\_OUT\_B summary registers, shown in IRQ\_OUT\_B summary register 0 (PIC\_IRQSR0) through IRQ\_OUT\_B summary register 2 (PIC\_IRQSR2) contain one bit for each interrupt source that can be routed to IRQ\_OUT\_B. The corresponding bit is set if the interrupt is active and is routed to IRQ\_OUT\_B (that is, if the corresponding xIDRn[EP] is set).

The critical interrupt summary registers, shown in Critical interrupt summary register 0 (PIC\_CISR0) through Critical interrupt summary register 2 (PIC\_CISR2), contain one bit for each interrupt source that can be designated as a critical interrupt. The corresponding bit is set if the interrupt is active and is routed to either the cint0 or cint1 outputs of the PIC (if xIDRn[CIn] = 1 in its corresponding destination register).

## 9.4.1.4 Performance monitor mask registers (PMMRs)

The twelve performance monitor mask registers consist of four sets of three 32-bit registers, PMnMR0, PMnMR1, and PMnMR2.

Each set can be configured to select one interrupt source (interprocessor, timer, message, shared message signaled, external, or internal) to generate a performance monitor event. The performance monitor can be configured to track this event in the performance monitor local control registers. See Performance monitor local control register A0 (PERFMON\_PMLCA0) and Performance monitor local control register B0 (PERFMON\_PMLCB0).

## 9.4.1.5 Message registers

The following registers support the message register interrupts:

- Message register n (PIC\_MSGR*n*)
- Message enable register (PIC\_MER)
- Message status register (PIC\_MSR)
- Messaging interrupt n (MSGn) vector/priority register (PIC\_MIVPRn)
- Messaging interrupt n (MSGn) destination register (PIC\_MIDRn)

Writing to one of the eight message registers (MSGR0-MSGR7) causes a messaging interrupt as directed by the other message registers listed above. Reading a message register clears the messaging interrupt. Note that a messaging interrupt can also be cleared by writing a one to the corresponding status field of the PIC message status register (MSR), shown in Message status register (PIC\_MSR).

## 9.4.1.6 Shared message signaled registers

This section contains description the shared message signaled interrupt registers (MSIRs).

The shared message signaled interrupt structure allows programs to interrupt each other by simply writing to these shared memory-mapped registers in the PIC.

Each of the eight MSIRs can be thought of as collecting interrupts from 32 different memory-mapped writes that can cause interrupts.

## 9.4.1.7 Interrupt source configuration registers

The interrupt source configuration registers control the source and destinations of interrupts, specifying parameters such as the interrupting event, signal polarity, and relative priority.

Table 9-322 shows the destination registers.

Table 9-322. Destination register summary

| Interrupt source                                                                        |        | 0  | 1   | 2   | 3 |  |   |  |  |  |  |   |   |  |  |   | 2<br>9 | 30 | 31 |
|-----------------------------------------------------------------------------------------|--------|----|-----|-----|---|--|---|--|--|--|--|---|---|--|--|---|--------|----|----|
| External (External interrupt n (IRQn) destination register (PIC_EIDRn)                  | R<br>W | EP | CI0 | CI1 | - |  | • |  |  |  |  | • | • |  |  | • |        | P1 | P0 |
| Internal (Internal interrupt n destination register (PIC_IIDRn)                         |        |    |     |     |   |  |   |  |  |  |  |   |   |  |  |   |        |    |    |
| Message signaled (Shared message signaled interrupt destination register n (PIC_MSIDRn) | R<br>W | 1  |     |     |   |  |   |  |  |  |  |   |   |  |  |   |        | P1 | P0 |
| Messaging (Messaging Interrupt Destination Registers)                                   |        |    |     |     |   |  |   |  |  |  |  |   |   |  |  |   |        |    |    |
| Global timer (Global timer n destination register group A (PIC_GTDRAn)                  |        |    |     |     |   |  |   |  |  |  |  |   |   |  |  |   |        |    |    |
| interprocessor ( Processor core 0 interprocessor n dispatch register (PIC_IPIDR_CPU0n)  |        |    |     |     |   |  |   |  |  |  |  |   |   |  |  |   |        |    |    |

## Note the following:

- The global timer, messaging interrupt and interprocessor destination register support only the P0 and P1 options. That is, they cannot be routed to *cint* or to IRQ\_OUT\_B.
- Only the global timer and interprocessor interrupts are multicasting, so only these interrupts allow more than one destination bit to be specified.

Table 9-323 shows the vector/priority registers.

Table 9-323. Vector/priority register summary



Table continues on the next page...

Table 9-323. Vector/priority register summary (continued)

|                                         | R | MSK | Α | - | P - |   |   | PRIORIT | VECTOR |
|-----------------------------------------|---|-----|---|---|-----|---|---|---------|--------|
| priority register (PIC_IIVPRn)          | W |     |   |   |     |   |   | Υ       |        |
| 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | R | MSK | Α | - | Р   | S | - | PRIORIT | VECTOR |
| vector/priority register (PIC_EIVPRn)   | W |     |   |   |     |   |   | Υ       |        |

### Note the following:

- The MSK, A, PRIORITY, and VECTOR fields have meaning only for interrupts routed to the *int* signal.
- The polarity field, P, is provided to indicate whether the signals from the corresponding source are active high or low.
- The sense field, S, is provided to allow external interrupt sources to be configured as level-sensitive so they can be routed to either *cint* or IRQ\_OUT\_B.

## 9.4.1.8 Per-CPU (private access) registers

The OpenPIC programming model supports multiprocessor systems of up to 32 separate processors.

As such, the OpenPIC interface specification provides for coordinating both the requesting and servicing of interrupts among several processor cores within a single integrated device. To comply with the OpenPIC specification, the PIC incorporates several of these multiprocessor capabilities.

#### NOTE

Note that these registers are meaningful only for interrupts routed to *int*.

The registers in the table below are called per-CPU registers because they are duplicated for each core in a multi-core device. The OpenPIC interface specifies that a copy of these registers be available to each core at the same physical address by using the ID of the processor core that initiates the transaction to determine the set of per-CPU registers to access.

Table 9-324. Per-CPU registers-private access address offsets

| Register name                               | Offset |
|---------------------------------------------|--------|
| Interprocessor 0 dispatch register (IPIDR0) | 0x0040 |
| Interprocessor 1 dispatch register (IPIDR1) | 0x0050 |
| Interprocessor 2 dispatch register (IPIDR2) | 0x0060 |
| Interprocessor 3 dispatch register (IPIDR3) | 0x0070 |

Table continues on the next page...

#### **Functional description**

Table 9-324. Per-CPU registers-private access address offsets (continued)

| Register name                         | Offset |
|---------------------------------------|--------|
| Current task priority register (CTPR) | 0x0080 |
| Who am I register (WHOAMI0)           | 0x0090 |
| Interrupt acknowledge register (IACK) | 0x00A0 |
| End of interrupt register (EOI)       | 0x00B0 |

These addresses, shown in Table 9-324, appear in the memory map at the same offset for every processor in what is called the private access space. This duplication allows user code to execute correctly in an multiprocessor environment without needing to know which core it is running on. On a single-core device, each register has two addresses, one in the normal address space and one in the private access space. It is included on even single-core devices to simplify the porting of such code.

Figure 9-320 shows how the duplicated registers are addressed in a four-core device. Note that when accessing a register normally, each core sources a different address. However, when accessing the same register using the per-CPU address space, each core sources the same address.



Figure 9-320. Per-CPU register address decoding in a four-core device

## 9.4.2 Flow of interrupt control

Figure 9-321 shows the flow of interrupts directed by the PIC to the *int*, *cint*, and IRQ\_OUT\_B outputs. Note that this diagram describes a conceptual model of an PIC on a single processor. This logic is replicated for each implemented processor. This conceptual diagram does not fully represent all internal circuitry of the implementation.

This figure focusses especially on the OpenPIC-defined logic and shows how the PIC controls interrupt requests that target the *int* signal. The flow in Figure 9-321 is from the bottom to the top, and shows at the bottom how the destination register associated with each source determines the path.

## 9.4.2.1 Interrupts routed to cint or IRQ\_OUT\_B

Interrupt requests routed to *cint* or IRQ\_OUT\_B bypass the logic that is dedicated to interrupt sources that compete for *int*.

That is, if xIDRn[CIn] or xIDRn[EP] = 1, corresponding xIVPR field settings have no hardware effects; however, an interrupt handler may be able to make use of some of those fields.

cint signals are connected to the respective core's critical interrupt input.

#### NOTE

Because interrupt sources routed to *cint* or IRQ\_OUT\_B must be level sensitive, EIVPR[S] should be set. See External interrupt n (IRQn) vector/priority register (PIC\_EIVPRn).

Because these interrupts bypass the OpenPIC logic, it is especially important that handlers do not read IACK. Doing so causes a spurious interrupt. Likewise, they should not write EOI.

## 9.4.2.2 Interrupts routed to int

As shown in the figure below, the PIC receives interrupt requests from external and internal sources and from within the PIC itself.

As the figure shows, all of these interrupt sources can be routed to *int*; the global timer and timer processor interrupts can be directed only to *int*.

The sources' mask bits (xVPRn[MSK]) are tracked in the internal mask register. If a source's MSK bit is set, the mask register prevents the PIC from asserting *int* on its behalf.

Unmasked interrupt requests are qualified and latched in the interrupt pending register (IPR), an internal interrupt summary register with a bit for each source. If an interrupt request is multi-cast, a bit is set in the IPR for each targeted processor. Although the IPR cannot be read by software, when an IPR bit is set, the corresponding source's activity bit (xVPRn[A]) is automatically set.

The interrupt selector monitors the IPR and the in-service register (ISR), which tracks previously taken interrupts that were superseded by a higher-priority interrupt before the interrupt handler finished. The interrupt selector recognizes the highest priority unmasked interrupt request and latches it into the interrupt request register (IRR). The source's vector (xVPRn[VECTOR]) is copied to IACK[VECTOR], which the interrupt handler retrieves by reading IACK.

If the priority (*x*VPR*n*[PRIORITY]) of an interrupt latched in the IRR is higher than the value in the target processor's CTPR[TASKP], the interrupt router asserts the external interrupt signal (*int*), causing that processor core to vector to its external interrupt handler.

Note that like IPR, ISR and IRR cannot be read by software.



If cint or IRQ\_OUT is the destination, EIVPRn[S] must be set to configure the source as level sensitive.

Figure 9-321. PIC interrupt processing flow diagram for each core (n)

The interrupt handler must acknowledge the interrupt by explicitly reading the corresponding IACK registers, described in Processor core 0 interrupt acknowledge register and Processor core 0 interrupt acknowledge register. The PIC interprets this read

If multiple destination register bits are set, PIC behavior is undefined.

Although setting CIn directs the interrupt request to the critical interrupt output (cint0/cint1), integrated logic may connect this signal to a different interrupt input to the core.

#### **Functional description**

as an interrupt acknowledge (IACK) cycle. The IACK cycle not only returns the source's vector, it also negates the *int* signal to the processor (making it possible for a higher priority interrupt to assert *int*) and sets the source's bit in the ISR, indicating that this interrupt has been put in service. An interrupt remains in service from the time until the corresponding end-of-interrupt register (EOI) is written, generating what the PIC considers an EOI signal.

### 9.4.2.2.1 Interrupt source priority

Each interrupt source routed to *int* is assigned a value through its *x*VPR*n*[PRIORITY] field.

Priority values range from 0 to 15, where 15 is the highest. Interrupts are delivered only when the priority of the source is greater than the destination processor's CTPR[TASKP]. Therefore, setting *x*VPR*n*[PRIORITY] to zero inhibits that interrupt. Likewise, setting TASKP to 15 prevents the PIC from delivering interrupts to that core through the *int* signal. Note that this is the reset value, preventing the PIC from asserting *int* before the PIC is configured.

The PIC services simultaneous interrupts occurring with the same priority according to the following order:

- 1. MSG0-MSG 7
- 2. MSI0-MSI7
- 3. IPI0-IPI3
- 4. Group A timer0-timer3
- 5. Group B timer0-timer3
- 6. IRQ[0:6]/PCIINT*x*
- 7. Internal 0-internal 63

For example, if MSG0, MSG2, and IPI0 are all assigned the same priority and receive simultaneous interrupts, they are serviced in the following order:

- 1. MSG0
- 2. MSG2
- 3. IPI0

## 9.4.2.2.2 Interrupt acknowledge

When the PIC causes *int* to be asserted, the external interrupt service routine acknowledges the request by reading that core's IACK register, which at this point holds the 16-bit vector value for the interrupt source that generated the request.

This is the value programmed in that source's *x*VPR*n*[VECTOR]. Reading IACK has the following effects:

- The *int* signal for that core is negated, making it possible for another interrupt source to signal an external interrupt to the core, and more particularly, allowing the PIC to signal a higher-priority interrupt, as described in Nesting of interrupts.
- The source that caused that resource is represented in the internal in-service register (ISR).

The interrupt is then considered to be in service. It remains so until the processor core performs a write to the corresponding EOI. Writing to EOI is referred to as an EOI cycle.

### 9.4.2.2.3 Spurious vector generation

Under certain circumstances, the PIC has no valid vector to return to a processor core during an interrupt acknowledge cycle.

In these cases, the spurious vector from the spurious vector register is returned. The following cases cause a spurious vector fetch:

- *int* is asserted in response to an externally or internally-sourced interrupt which is activated with level-sensitive logic, and the asserted level is negated before the interrupt is acknowledged.
- *int* is asserted for an interrupt source that is later masked (using the mask bit in the vector/priority register corresponding to that source) before the interrupt is acknowledged.
- *int* is asserted for an interrupt source that is later masked by an increase in the task priority level before the interrupt is acknowledged.
- An interrupt acknowledge cycle is performed by the processor core in spite of the fact that the *int* signal has not been asserted by the PIC.

In all cases, a spurious vector is returned only if no pending interrupt has sufficient priority to signal an interrupt, otherwise, the vector for that interrupt source is returned.

#### **NOTE**

EOI should not be written in response to a spurious vector. Otherwise, a previously accepted interrupt might be cleared unintentionally.

# 9.4.2.2.4 Nesting of interrupts

While an interrupt is being handled, if an interrupt request arrives with a higher xVPRn[PRIORITY] value, the interrupt being serviced is superseded.

#### **Functional description**

As described in Interrupts routed to *int*, the PIC asserts *int*, and the newer, higher priority interrupt is handled. This happens even if software, as part of its interrupt service routine, updates the corresponding CTPR with a lower value.

Thus, although several interrupts can be in service simultaneously (and tracked by the ISR), the highest priority interrupt by that processor is always the one actively handled. When the interrupt routine completes, it performs a write EOI cycle, a side effect of which is to take the current highest priority interrupt out of service (removes it from the ISR). At this point, the interrupt selector chooses the new highest priority interrupt request, and, assuming CTPR[TASKP] has not been updated to a value higher than the new interrupt, the PIC asserts *int* on its behalf.

The next write EOI cycle takes the current highest priority interrupt out of service. An interrupt with lower priority than those in service is not started until all higher priority interrupts complete even if its priority is greater than the CTPR value.

# 9.4.3 Interprocessor interrupts

Processors 0 and 1 can generate interprocessor interrupts that target either or both processors.

A self interrupt occurs when a core dispatches an interprocessor interrupt event to itself.

Interrupts are initiated by writing either or both of the PO*n* bits in an interprocessor interrupt dispatch register (IPIDR0-IPIDR3) of one of the four IPI channels. If subsequent interprocessor interrupts from a given channel to a given target processor are initiated before the first is acknowledged, only one interrupt is generated.

# 9.4.4 Message interrupts

The eight MSGRs described in Message register n (PIC\_MSGRn), can be used to send 32-bit messages to one or more processors.

A messaging interrupt is generated by writing an MSGR if the corresponding MER bit is set and the interrupt is not masked. Reading a MSGR or writing a 1 to the status bit clears the interrupt.

# 9.4.5 Shared message signaled interrupts

There are eight shared MSIRs, Shared message signaled interrupt register n (PIC\_MSIRn), that indicate which of the interrupt sources sharing the MSI register have pending interrupts.

Up to 32 sources can share any individual MSI register. A shared message signaled interrupt is generated by writing to Shared Message Signaled Interrupt Index Register (MSIIR) fields SRS and IBS. This register is primarily intended to support inbound PCI Express message signaled interrupts (MSIs) when the PCI Express controller is configured as a root complex (RC).

MSIIR[SRS] selects the associated MSIR and MSIIR[IBS] selects the interrupt flag/bit in that register that is to be set. The corresponding interrupt needs to be unmasked for the interrupt to occur. A read to an MSIR clears the all of its flags.

# 9.4.6 PCI Express INTx/IRQn sharing

Whenever the PCI Express controller is in root complex mode and it receives an inbound INTx asserted or negated message transaction, it asserts or negates an equivalent internal INTx signal to the PIC. This INTx virtual-wire interrupt signaling mechanism replaces the PCI standard sideband interrupts (INTA, INTB, INTC, and INTD) that historically were connected to the IRQn external interrupt inputs.

The internal INTx signals from the PCI Express controller are logically combined with the interrupt request (IRQn) signals so that they share the same OpenPIC external interrupt controlled by the associated EIVPRn and EIDRn registers.

**PCI Express number** INTx **IRQn** PCI Express 1 INTA IRQ0 INTB IRQ1 INTC IRQ2 INTD IRQ3 INTA PCI Express 2 IRQ4 INTB IRQ5 INTC IRQ6 INTD

Table 9-325. PCI Express INTx/IRQn sharing

#### **Functional description**

In general, these signals should be considered mutually exclusive. If a PCI Express INTx signal is being used, the PIC must be configured so that external interrupts are level sensitive (EIVPRn[S] = 1). If an IRQn signal is being used as edge-triggered (EIVPRn[S] = 0), the system must not allow inbound PCI Express INTx transactions.

Note that it is possible to share IRQn and INTx if the external interrupt is level sensitive; however, if an interrupt occurs, the interrupt service routine must poll both the external sources connected to the IRQn input and the PCI Express INTx sources to determine from which path the external interrupt came. In any case, IRQn should be pulled to the negated state as determined by the associated polarity setting in EIVPRn[P].

#### 9.4.7 Global timers

There are appropriate clock prescalers and synchronizers to provide a time base for the internal PIC timers.

These 8 timers are organized as 2 groups of 4 timers each. The timers can be individually programmed to generate a processor core interrupt when they count down to zero and can be used to generate regular periodic interrupts. Each timer has the following four configuration and control registers:

- Global timer current count register (GTCCRxn)
- Global timer base count register (GTBCRxn)
- Global timer vector-priority register (GTVPR*xn*)
- Global timer destination register (GTDR*xn*)

The timer frequency should be written to the TFRR*xn*, described in Timer frequency reporting register group X (PIC\_TFRR*n*).

Timer interrupts are all edge-triggered interrupts. If a timer period expires while a previous interrupt from the same source is pending or in service, the subsequent interrupt is lost.

The timer control register (TCR) provides users with the ability to create timers larger than the 31-bit global timers. The timer frequency can also be changed by setting the appropriate TCR fields, as described in Timer control register group n (PIC\_TCRn).

### 9.4.8 Resets

This section describes the behavior of the PIC at reset and the PIC's ability to initiate processor resets.

# 9.4.9 Resetting the PIC

The PIC is reset by a device power-on reset (POR) or by software that sets GCR[RST], either of which causes the following:

- All pending and in-service interrupts are cleared.
- All interrupt mask bits are set.
- Polarity, sense, external signal, critical interrupt, and activity fields are reset to default values.
- PIR, TFRR, TCR, MER, MSR, and MSGR0-MSGR 7 are cleared.
- MSG and timer destination fields are set.
- The interprocessor dispatch registers are cleared.
- All timer base count values are reset to zero with count inhibited.
- CTPR[TASKP] is reset to 0x000F, disabling delivery of interrupts that target int.
- The spurious interrupt vector resets to 0xFFFF.
- The PMnMRs are reset to 0xFFFF.
- The PIC defaults to the pass-through mode (GCR[M] = 0).
- All other registers remain at their pre-reset programmed values.

GCR[RST] is automatically cleared when the reset sequence is complete.

#### 9.4.9.1 Processor core initialization

A software reset can be routed to either of the cores by writing to the processor core initialization register (PIR).

This causes the assertion of the corresponding *core\_hreset* output signal from the PIC. When this occurs, the corresponding CTPR also gets written to 0x000F to prevent delivery of any interrupts to *int*.

# 9.5 Initialization/application information

This section contains initialization and application information for the PIC.

# 9.5.1 Programming guidelines

The following subsections contain information about programming PIC registers.

### 9.5.1.1 PIC registers

Most PIC control and status registers are readable and return the last value written.

The exceptions to this rule are as follows:

- Interprocessor dispatch and EOI registers, which return zeros on reads.
- Activity bits (A) of the vector/priority registers reflect the status of the corresponding interrupt source.
- IACK, which returns the vector of the highest priority pending interrupt or the spurious vector (SVR[VECTOR]) if none is pending.
- Reserved fields always return 0.

When the PIC is in mixed mode (GCR[M] = 1), the following guidelines are recommended:

- All PIC registers must be located in a cache-inhibited, guarded area (configured through the core's MMU).
- The PIC portion of the address map must be set up appropriately.

In addition, the following initialization sequence is recommended:

- 1. Write the vector, priority, and polarity values in each interrupt's vector/priority register, leaving their MSK (mask) bit set. This is required only if interrupts are used.
- 2. Clear CTPR (CTPR = all zeros).
- 3. Program the PIC to mixed mode by setting GCR[M].
- 4. Clear the MSK bit in the vector/priority registers to be used.
- 5. Perform a software loop to clear all pending interrupts:
  - Load counter with FRR[NIRQ].
  - While counter > 0, read IACK and write EOI to guarantee all the IPR and ISR bits are cleared.
- 6. Set the processor core CTPR values to the desired values.
- 7. Set MER to 0x0000\_000F. See Message enable register (PIC\_MER), for more information.

Depending on the interrupt system configuration, the PIC may generate spurious interrupts to clear interrupts latched during power-up. A spurious or non-spurious vector is returned for an interrupt acknowledge cycle in this case. See the programming note below for the non-spurious case.

#### NOTE

Because the default polarity/sense for external interrupts is edge-sensitive, and edge-sensitive interrupts are not cleared until they are acknowledged, it is possible for the PIC to store spurious edges detected during power-up as pending external interrupts. If software permanently configures an external interrupt source to be edge-sensitive, it may receive the vector for the interrupt source and not a spurious interrupt vector when software clears the mask bit. This can occur once for any edge-sensitive interrupt when its mask bit is first cleared and the PIC is in mixed mode.

To avoid a false interrupt for this case, software can clear the IPR of these spurious edge detections by first configuring the polarity/sense of external interrupt sources to be level-sensitive: high-level if the input is a positive-edge source and low-level if it is a negative-edge source (while the mask bit remains set). After this is complete, configuring the external interrupt source as edge-sensitive does not cause a false interrupt.

### 9.5.1.2 Changing interrupt source configuration

To change the vector, priority, polarity, sense, or destination of an active (unmasked) interrupt source, the following steps should be taken:

- 1. Mask the source using the mask (MSK) bit in the vector/priority register.
- 2. Wait for the activity (A) bit for that source to be cleared.
- 3. Make the desired changes.
- 4. Unmask the source.

Note that changing the destination from *int* to *cint* or IRQ\_OUT\_B makes the A, MSK, and PRIORITY fields meaningless.

Initialization/application information

# Chapter 10 I2C Interfaces

This chapter describes the dual inter-integrated circuit (I2C) bus modules implemented on this device.

### 10.1 Overview

This chapter describes the dual inter-integrated circuit (I<sup>2</sup>C) bus modules implemented on this device and covers the following topics:

- Introduction to I<sup>2</sup>C
- I<sup>2</sup>C external signal descriptions
- I2C memory map/register definition
- Functional description
- Initialization/application information

# 10.2 Introduction to I<sup>2</sup>C

This section presents the following topics:

- What is the I<sup>2</sup>C module?
- I<sup>2</sup>C module block diagram
- Features
- Advantages of the I<sup>2</sup>C bus
- Modes of operation
- I<sup>2</sup>C-specific conditions

# 10.2.1 What is the I<sup>2</sup>C module?

The I<sup>2</sup>C module is a two-wire-serial data (SDA) and serial clock (SCL)-bidirectional serial bus that provides a simple efficient method of data exchange between this device and other devices, such as microcontrollers, EEPROMs, real-time clock devices, A/D converters, and LCDs.

# 10.2.2 I<sup>2</sup>C module block diagram



Figure 10-1. I<sup>2</sup>C block diagram

### 10.2.3 Features

The I<sup>2</sup>C interface includes the following features:

- Two-wire interface
- Multiple-master operation

- Arbitration lost interrupt with automatic mode switching from master to slave
- Calling address identification interrupt
- START and STOP signal generation/detection
- Acknowledge bit generation/detection
- Bus busy detection
- Software-programmable clock frequency
- Software-selectable acknowledge bit
- On-chip filtering for spikes on the bus

# 10.2.4 Advantages of the I<sup>2</sup>C bus

The two-wire I<sup>2</sup>C bus minimizes interconnections between devices.

The synchronous, multiple-master I<sup>2</sup>C bus allows the connection of additional devices to the bus for expansion and system development. The bus includes collision detection and arbitration that prevent data corruption if two or more masters attempt to control the bus simultaneously.

# 10.2.5 Modes of operation

The I<sup>2</sup>C units on this device can operate in one of the following modes:

- Master mode-The I<sup>2</sup>C is the driver of the SDA line. It cannot use its own slave address as a calling address. The I<sup>2</sup>C cannot be a master and a slave simultaneously.
- Slave mode-The I<sup>2</sup>C is not the driver of the SDA line. The module must be enabled before a START condition from a non-I<sup>2</sup>C master is detected.
- Interrupt-driven byte-to-byte data transfer-When successful slave addressing is achieved (and SCL returns to zero), the data transfer can proceed on a byte-to-byte basis in the direction specified by the R/W\_B bit sent by the calling master. Each byte of data must be followed by an acknowledge bit, which is signaled from the receiving device. Several bytes can be transferred during a data transfer session.
- Boot sequencer mode-This mode can be used to initialize the configuration registers in the device after the I<sup>2</sup>C1 module is initialized. Note that the device powers up with boot sequencer mode disabled as a default, but this mode can be selected with the cfg\_boot\_seq[0:1] power-on reset (POR) configuration signals that are located on the LGPL3 and LGPL5 signals.

# 10.2.6 I<sup>2</sup>C-specific conditions

The following three conditions are defined for the I<sup>2</sup>C interface:

- START condition-This condition denotes the beginning of a new data transfer (each data transfer contains several bytes of data) and awakens all slaves.
- Repeated START condition-A START condition that is generated without a STOP condition to terminate the previous transfer.
- STOP condition-The master can terminate the transfer by generating a STOP condition to free the bus.

# 10.3 I<sup>2</sup>C external signal descriptions

The following sections give an overview of signals and provide detailed signal descriptions.

# 10.3.1 Signal overview

The I<sup>2</sup>C interface uses the SDA and SCL signals, described in the table below for data transfer.

Note that the signal patterns driven on SDA represent address, data, or read/write information at different stages of the protocol.

Table 10-1. I<sup>2</sup>C interface signal descriptions

| Signal name                | Idle state | 1/0 | State meaning                                                                                                                                                                                                         |  |  |
|----------------------------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Serial clock<br>(IICn_SCL) |            |     | When the I <sup>2</sup> C module is idle or acts as a slave, SCL defaults as an input. The unit uses SCL to synchronize incoming data on SDA. The bus is assumed to be busy when SCL is detected low.                 |  |  |
|                            |            | 0   | As a master, the I <sup>2</sup> C module drives SCL along with SDA when transmitting. As a slave, the I <sup>2</sup> C module drives SCL low for data pacing.                                                         |  |  |
| Serial data<br>(IICn_SDA)  |            | I   | When the I <sup>2</sup> C module is idle or in a receiving mode, SDA defaults as an input. The unit receives data from other I <sup>2</sup> C devices on SDA. The bus is assumed to be busy when SDA is detected low. |  |  |
|                            |            | 0   | When writing as a master or slave, the I <sup>2</sup> C module drives data on SDA synchronous to SCL.                                                                                                                 |  |  |

# 10.3.2 Detailed signal descriptions

SDA and SCL, described in the table below, serve as a communication interconnect with other devices. All devices connected to these two signals must have open-drain or open-collector outputs. The logic AND function is performed on both of these signals with external pull-up resistors. Refer to the device hardware specifications for the electrical characteristics of these signals.

| Signal   | I/O |                                                                                                                                                                                            | Description                                                                                                                                                                          |  |  |  |
|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| IICn_SCL | I/O | Serial clock. Performs as an input when the device is programmed as an I <sup>2</sup> C slave. SCL also performs as an output when the device is programmed as an I <sup>2</sup> C master. |                                                                                                                                                                                      |  |  |  |
|          | 0   | As outputs                                                                                                                                                                                 | s outputs for the bidirectional serial clock, these signals operate as described below.                                                                                              |  |  |  |
|          |     | State meaning                                                                                                                                                                              |                                                                                                                                                                                      |  |  |  |
|          | I   | As inputs                                                                                                                                                                                  | s inputs for the bidirectional serial clock, these signals operate as described below.                                                                                               |  |  |  |
|          |     | State<br>Meaning                                                                                                                                                                           |                                                                                                                                                                                      |  |  |  |
| IICn_SDA | I/O |                                                                                                                                                                                            | al data. Performs as an input when the device is in a receiving mode. SDA also performs as an output all when the device is transmitting (as an I <sup>2</sup> C master or a slave). |  |  |  |
|          | 0   | As outputs                                                                                                                                                                                 | As outputs for the bidirectional serial data, these signals operate as described below.                                                                                              |  |  |  |
|          |     | State meaning                                                                                                                                                                              | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                |  |  |  |
|          | I   | As inputs                                                                                                                                                                                  | As inputs for the bidirectional serial data, these signals operate as described below.                                                                                               |  |  |  |
|          |     | State meaning                                                                                                                                                                              |                                                                                                                                                                                      |  |  |  |

Table 10-2. I<sup>2</sup>C interface signal-detailed signal descriptions

# 10.4 I2C memory map/register definition

The following table lists the  $I^2C$ -specific registers and their offsets. It lists the offset, name, and a cross-reference to the complete description of each register. Note that the full register address is comprised of CCSRBAR together with the block base address and offset listed in the table below. The offsets to the memory map table are defined for both  $I^2C$  interfaces. That is,  $I^2C1$  starts at address offset 0x000, and  $I^2C2$  starts at address offset 0x100. Note that the registers are the same for  $I^2C2$  except that the offsets change from 0x0*nn* to 0x1*nn*.

All I<sup>2</sup>C registers are one byte wide. Reads and writes to these registers must be byte-wide operations.

#### **NOTE**

Reserved bits should always be written with the value they returned when read. That is, the register should be programmed by reading the value, modifying appropriate fields, and writing back the value. The return value of the reserved fields should not be assumed, even though the reserved fields return zero.

This note does not apply to the I2C data register (I2CDR).

#### **I2C** memory map

| Offset address (hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-----------------------------------------------------------|--------------------|--------|-------------|------------------|
| 3000                 | I2C address register (I2C1_I2CADR)                        | 8                  | R/W    | 00h         | 10.4.1/482       |
| 3004                 | I2C frequency divider register (I2C1_I2CFDR)              | 8                  | R/W    | 00h         | 10.4.2/483       |
| 3008                 | I2C control register (I2C1_I2CCR)                         | 8                  | R/W    | 00h         | 10.4.3/485       |
| 300C                 | I2C status register (I2C1_I2CSR)                          | 8                  | R/W    | 81h         | 10.4.4/486       |
| 3010                 | I2C data register (I2C1_I2CDR)                            | 8                  | R/W    | 00h         | 10.4.5/487       |
| 3014                 | I2C digital filter sampling rate register (I2C1_I2CDFSRR) | 8                  | R/W    | 10h         | 10.4.6/488       |
| 3100                 | I2C address register (I2C2_I2CADR)                        | 8                  | R/W    | 00h         | 10.4.1/482       |
| 3104                 | I2C frequency divider register (I2C2_I2CFDR)              | 8                  | R/W    | 00h         | 10.4.2/483       |
| 3108                 | I2C control register (I2C2_I2CCR)                         | 8                  | R/W    | 00h         | 10.4.3/485       |
| 310C                 | I2C status register (I2C2_I2CSR)                          | 8                  | R/W    | 81h         | 10.4.4/486       |
| 3110                 | I2C data register (I2C2_I2CDR)                            | 8                  | R/W    | 00h         | 10.4.5/487       |
| 3114                 | I2C digital filter sampling rate register (I2C2_I2CDFSRR) | 8                  | R/W    | 10h         | 10.4.6/488       |

# 10.4.1 I2C address register (I2Cx\_I2CADR)

The figure below shows the I2CADR register, which contains the address to which the I<sup>2</sup>C interface responds when addressed as a slave. Note that this is not the address that is sent on the bus during the address-calling cycle when the I<sup>2</sup>C module is in master mode.

Address: Base address + 0h offset



### I2Cx\_I2CADR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                            |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ADDR  | Slave address. Contains the specific slave address that is used by the I <sup>2</sup> C interface. Note that the default mode of the I <sup>2</sup> C interface is slave mode for an address match. Note that an address match is one of the conditions that can cause I2CSR[MIF] to be set, signaling an interrupt pending condition. |  |
| 7 -   | This field is reserved.                                                                                                                                                                                                                                                                                                                |  |

# 10.4.2 I2C frequency divider register (I2Cx\_I2CFDR)

Refer to application note AN2919, "Determining the I2C Frequency Divider Ratio for SCL," for additional guidance regarding the proper use of I2CFDR and I2CDFSRR.





#### I2Cx\_I2CFDR field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1        | This field is reserved.                                                                                                                                                                                                                                                                                                                                           |
| -          |                                                                                                                                                                                                                                                                                                                                                                   |
| 2–7<br>FDR | Frequency divider ratio. Used to prescale the clock for bit rate selection. The serial bit clock frequency of SCL is equal to one half the platform ( CCB ) clock divided by the designated divider . Note that the frequency divider value can be changed at any point in a program. The serial bit clock frequency divider selections are described as follows: |
|            | FDRDivider (Decimal)                                                                                                                                                                                                                                                                                                                                              |
|            | 0x00 384                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x01 416                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x02 480                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x03 576                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x04 640                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x05 704                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x06 832                                                                                                                                                                                                                                                                                                                                                          |
|            | 0x07 1024                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x08 1152                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x09 1280                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0A 1536                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0B 1920                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0C 2304                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0D 2560                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0E 3072                                                                                                                                                                                                                                                                                                                                                         |
|            | 0x0F 3840                                                                                                                                                                                                                                                                                                                                                         |

Table continues on the next page...

# I2Cx\_I2CFDR field descriptions (continued)

| 0x10 4608 0x11 5120 0x12 6144 0x13 7680 0x14 9216 0x15 10240 0x16 12288 0x17 15360 0x18 18432 0x19 20480 0x1A 24576 0x1B 30720 0x1C 36864 0x1D 40960 0x1E 49152 0x1F 61440 0x20 256 0x21 288 0x22 320 0x23 352 0x24 384                      |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0x11 5120 0x12 6144 0x13 7680 0x14 9216 0x15 10240 0x16 12288 0x17 15360 0x18 18432 0x19 20480 0x1A 24576 0x1B 30720 0x1C 36864 0x1D 40960 0x1E 49152 0x1F 61440 0x20 256 0x21 288 0x22 320 0x23 352 0x24 384                                |  |
| 0x13 7680<br>0x14 9216<br>0x15 10240<br>0x16 12288<br>0x17 15360<br>0x18 18432<br>0x19 20480<br>0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384 |  |
| 0x14 9216 0x15 10240 0x16 12288 0x17 15360 0x18 18432 0x19 20480 0x1A 24576 0x1B 30720 0x1C 36864 0x1D 40960 0x1E 49152 0x1F 61440 0x20 256 0x21 288 0x22 320 0x23 352 0x24 384                                                              |  |
| 0x15 10240<br>0x16 12288<br>0x17 15360<br>0x18 18432<br>0x19 20480<br>0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                           |  |
| 0x16 12288 0x17 15360 0x18 18432 0x19 20480 0x1A 24576 0x1B 30720 0x1C 36864 0x1D 40960 0x1E 49152 0x1F 61440 0x20 256 0x21 288 0x22 320 0x23 352 0x24 384                                                                                   |  |
| 0x17 15360<br>0x18 18432<br>0x19 20480<br>0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                       |  |
| 0x18 18432<br>0x19 20480<br>0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                     |  |
| 0x19 20480<br>0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                   |  |
| 0x1A 24576<br>0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                 |  |
| 0x1B 30720<br>0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                               |  |
| 0x1C 36864<br>0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                             |  |
| 0x1D 40960<br>0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                                           |  |
| 0x1E 49152<br>0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                                                         |  |
| 0x1F 61440<br>0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                                                                       |  |
| 0x20 256<br>0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                                                                                     |  |
| 0x21 288<br>0x22 320<br>0x23 352<br>0x24 384                                                                                                                                                                                                 |  |
| 0x22 320<br>0x23 352<br>0x24 384                                                                                                                                                                                                             |  |
| 0x23 352<br>0x24 384                                                                                                                                                                                                                         |  |
| 0x24 384                                                                                                                                                                                                                                     |  |
|                                                                                                                                                                                                                                              |  |
|                                                                                                                                                                                                                                              |  |
| 0x25 448                                                                                                                                                                                                                                     |  |
| 0x26 512                                                                                                                                                                                                                                     |  |
| 0x27 576                                                                                                                                                                                                                                     |  |
| 0x28 640                                                                                                                                                                                                                                     |  |
| 0x29 768                                                                                                                                                                                                                                     |  |
| 0x2A 896                                                                                                                                                                                                                                     |  |
| 0x2B 1024                                                                                                                                                                                                                                    |  |
| 0x2C 1280                                                                                                                                                                                                                                    |  |
| 0x2D 1536<br>0x2E 1792                                                                                                                                                                                                                       |  |
| 0x2E 1792<br>0x2F 2048                                                                                                                                                                                                                       |  |
| 0x30 2560                                                                                                                                                                                                                                    |  |
| 0x31 3072                                                                                                                                                                                                                                    |  |
| 0x32 3584                                                                                                                                                                                                                                    |  |
| 0x33 4096                                                                                                                                                                                                                                    |  |
| 0x34 5120                                                                                                                                                                                                                                    |  |
| 0x35 6144                                                                                                                                                                                                                                    |  |
| 0x36 7168                                                                                                                                                                                                                                    |  |
| 0x37 8192                                                                                                                                                                                                                                    |  |
| 0x38 10240                                                                                                                                                                                                                                   |  |
| 0x39 12288                                                                                                                                                                                                                                   |  |
| 0x3A 14336                                                                                                                                                                                                                                   |  |
| 0x3B 16384                                                                                                                                                                                                                                   |  |
| 0x3C 20480                                                                                                                                                                                                                                   |  |
| 0x3D 24576                                                                                                                                                                                                                                   |  |
| 0x3E 28672                                                                                                                                                                                                                                   |  |
| 0x3F 32768                                                                                                                                                                                                                                   |  |

# 10.4.3 I2C control register (I2Cx\_I2CCR)

Address: Base address + 8h offset



### I2Cx\_I2CCR field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MEN  | Module enable. This bit controls the software reset of the I <sup>2</sup> C module.                                                                                                                                                                                                                                                                                                         |
|           | O The module is reset and disabled. When low, the interface is held in reset but the registers can still be accessed.                                                                                                                                                                                                                                                                       |
|           | 1 The I <sup>2</sup> C module is enabled. This bit must be set before any other control register bits have any effect.  All I <sup>2</sup> C registers for slave receive or master START can be initialized before setting this bit.                                                                                                                                                        |
| 1<br>MIEN | Module interrupt enable                                                                                                                                                                                                                                                                                                                                                                     |
|           | <ul> <li>Interrupts from the I<sup>2</sup>C module are disabled. This does not clear any pending interrupt conditions.</li> <li>Interrupts from the I<sup>2</sup>C module are enabled. An interrupt occurs provided I2CSR[MIF] is also set.</li> </ul>                                                                                                                                      |
| 2<br>MSTA | Master/slave mode START                                                                                                                                                                                                                                                                                                                                                                     |
|           | 0 When this bit is changed from one to zero, a STOP condition is generated and the mode changes from master to slave.                                                                                                                                                                                                                                                                       |
|           | 1 Cleared without generating a STOP condition when the master loses arbitration. When this bit is changed from zero to one, a START condition is generated on the bus, and master mode is selected.                                                                                                                                                                                         |
| 3<br>MTX  | Transmit/receive mode select. This bit selects the direction of the master and slave transfers. When configured as a slave, this bit should be set by software according to I2CSR[SRW]. In master mode, the bit should be set according to the type of transfer required. Therefore, for address cycles, this bit is always high. The MTX bit is cleared when the master loses arbitration. |
|           | 0 Receive mode                                                                                                                                                                                                                                                                                                                                                                              |
|           | 1 Transmit mode                                                                                                                                                                                                                                                                                                                                                                             |
| 4<br>TXAK | Transfer acknowledge. This bit specifies the value driven onto the SDA line during acknowledge cycles for both master and slave receivers. The value of this bit only applies when the I <sup>2</sup> C module is configured as a receiver, not a transmitter. It also does not apply to address cycles; when the device is addressed as a slave, an acknowledge is always sent.            |
|           | O An acknowledge signal (low value on SDA) is sent out to the bus at the 9th clock after receiving one byte of data.                                                                                                                                                                                                                                                                        |
|           | 1 No acknowledge signal response (high value on SDA) is sent.                                                                                                                                                                                                                                                                                                                               |
| 5<br>RSTA | Repeated START. Setting this bit always generates a repeated START condition on the bus, provides the device with the current bus master. Attempting a repeated START at the wrong time (or if the bus is owned by another master), results in loss of arbitration. Note that this bit is not readable, which means if a read is performed to I2CCR[RSTA], a zero value is returned.        |

Table continues on the next page...

# I2Cx\_I2CCR field descriptions (continued)

| Field | Description                                                                 |
|-------|-----------------------------------------------------------------------------|
|       | 0 No START condition is generated                                           |
|       | 1 Generates repeated START condition                                        |
| 6     | This field is reserved.                                                     |
| -     |                                                                             |
| 7     | Broadcast                                                                   |
| BCST  |                                                                             |
|       | 0 Disables the broadcast accept capability                                  |
|       | 1 Enables the I <sup>2</sup> C to accept broadcast messages at address zero |

# 10.4.4 I2C status register (I2Cx\_I2CSR)

The I<sup>2</sup>C status register is read only with the exception of the MIF and MAL bits, which can be cleared by software. The MCF and RXAK bits are set at reset; all other I2CSR bits are cleared on reset.

Address: Base address + Ch offset



### I2Cx\_I2CSR field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>MCF  | Data transfer. When one byte of data is transferred, the bit is cleared. It is set by the falling edge of the 9th clock of a byte transfer.                                                                                                                                                                                             |
|           | <ul> <li>Byte transfer in progress. MCF is cleared under either of the following conditions: When I2CDR is read in receive mode, When I2CDR is written in transmit mode</li> <li>Byte transfer is completed</li> </ul>                                                                                                                  |
| 1<br>MAAS | Addressed as a slave. When the value in I2CDR matches with the calling address, this bit is set. The processor is interrupted, if I2CCR[MIEN] is set. Next, the processor must check the SRW bit and set I2CCR[MTX] accordingly. Writing to the I2CCR automatically clears this bit.  0 Not addressed as a slave 1 Addressed as a slave |
| 2<br>MBB  | Bus busy. Indicates the status of the bus. When a START condition is detected, MBB is set. If a STOP condition is detected, it is cleared.  0 I <sup>2</sup> C bus is idle 1 I <sup>2</sup> C bus is busy                                                                                                                               |
| 3<br>MAL  | Arbitration lost. Automatically set when the arbitration procedure is lost. Note that the device does not automatically retry a failed transfer attempt.                                                                                                                                                                                |

Table continues on the next page...

# I2Cx\_I2CSR field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                     |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0 Arbitration is not lost. Can only be cleared by software                                                                                                                                                                                                                                                                                                      |
|            | 1 Arbitration is lost                                                                                                                                                                                                                                                                                                                                           |
| 4<br>BCSTM | Broadcast match                                                                                                                                                                                                                                                                                                                                                 |
|            | 0 There has not been a broadcast match.                                                                                                                                                                                                                                                                                                                         |
|            | 1 The calling address matches with the broadcast address instead of the programmed slave address. This also sets if this I <sup>2</sup> C drives an address of all 0s and broadcast mode is enabled.                                                                                                                                                            |
| 5<br>SRW   | Slave read/write. When MAAS is set, SRW indicates the value of the R/W command bit of the calling address, which is sent from the master.                                                                                                                                                                                                                       |
|            | 0 Slave receive, master writing to slave                                                                                                                                                                                                                                                                                                                        |
|            | 1 Slave transmit, master reading from slave. This bit is valid only when both of the following conditions are true: A complete transfer occurred and no other transfers have been initiated. The I <sup>2</sup> C interface is configured as a slave and has an address match.                                                                                  |
|            | By checking this bit, the processor can select slave transmit/receive mode according to the command of the master.                                                                                                                                                                                                                                              |
| 6<br>MIF   | Module interrupt. The MIF bit is set when an interrupt is pending, causing a processor interrupt request (provided I2CCR[MIEN] is set). The interrupts for I <sup>2</sup> C1 and I <sup>2</sup> C2 are combined into one interrupt, which is sourced by the dual I <sup>2</sup> C controller.                                                                   |
|            | 0 No interrupt is pending. Can be cleared only by software.                                                                                                                                                                                                                                                                                                     |
|            | 1 Interrupt is pending. MIF is set when one of the following events occurs: One byte of data is transferred (set at the falling edge of the 9th clock). The value in I2CADR matches with the calling address in slave-receive mode. Arbitration is lost.                                                                                                        |
| 7<br>RXAK  | Received acknowledge. The value of SDA during the reception of acknowledge bit of a bus cycle. If the received acknowledge bit (RXAK) is low, it indicates that an acknowledge signal has been received after the completion of eight bits of data transmission on the bus. If RXAK is high, it means no acknowledge signal has been detected at the 9th clock. |
|            | 0 Acknowledge received                                                                                                                                                                                                                                                                                                                                          |
|            | 1 No acknowledge received                                                                                                                                                                                                                                                                                                                                       |

# 10.4.5 I2C data register (I2Cx\_I2CDR)

Address: Base address + 10h offset



### I2Cx\_I2CDR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Transmission starts when an address and the R/W bit are written to the data register and the $I^2C$ interface performs as the master. A data transfer is initiated when data is written to the I2CDR. The most significant bit is sent first in both cases. In master receive mode, reading the data register allows the read to occur, but also allows the $I^2C$ module to receive the next byte of data on the I2C interface. In slave mode, the same function is available after it is addressed. Note that in both master receive and slave receive modes, the very first read is always a dummy read. |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 10.4.6 I2C digital filter sampling rate register (I2Cx\_I2CDFSRR)

The digital filter sampling rate register (I2CDFSRR) is shown in the figure below. Refer to application note AN2919, "Determining the I2C Frequency Divider Ratio for SCL," for additional guidance regarding the proper use of I2CFDR and I2CDFSRR.





#### I2Cx\_I2CDFSRR field descriptions

| Field | Description                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1   | This field is reserved.                                                                                                                                                                                                          |
| -     |                                                                                                                                                                                                                                  |
| 2–7   | Digital filter sampling rate. To assist in filtering out signal noise, the sample rate is programmed. This field                                                                                                                 |
| DFSR  | is used to prescale the frequency at which the digital filter takes samples from the $I^2C$ bus. The resulting sampling rate is calculated by dividing one half the platform (CCBclock) frequency by the non-zero value of DFSR. |

# 10.5 Functional description

The I<sup>2</sup>C unit always performs as a slave receiver as a default, unless explicitly programmed to be a master or slave transmitter. After the boot sequencer has completed (when powered up in boot sequencer mode), the I<sup>2</sup>C interface performs as a slave receiver.

Note that the boot sequencer only functions from the I<sup>2</sup>C1 interface; the I<sup>2</sup>C2 interface cannot be used for this purpose.

# 10.5.1 Transaction protocol

A standard I<sup>2</sup>C transfer consists of the following:

- START condition
- Slave target address transmission
- Data transfer
- STOP condition

The following figure shows the interaction of these four parts with the calling address, data byte, and new calling address components of the I<sup>2</sup>C protocol. The details of the protocol are described in the following sections.



Figure 10-20. I<sup>2</sup>C interface transaction protocol

#### 10.5.1.1 START condition

When the I<sup>2</sup>C bus is not engaged (both SDA and SCL lines are at logic high), a master can initiate a transfer by sending a START condition.

As shown in Figure 10-20, a START condition is defined as a high-to-low transition of SDA while SCL is high. This condition denotes the beginning of a new data transfer. Each data transfer can contain several bytes and awakens all slaves. The START condition is initiated by a software write that sets I2CCR[MSTA].

### 10.5.1.2 Slave address transmission

The first byte of data is transferred by the master immediately after the START condition is the slave address.

#### **Functional description**

This is a seven-bit calling address followed by a R/W\_B bit, which indicates the direction of the data being transferred to the slave. Each slave in the system has a unique address. In addition, when the I<sup>2</sup>C module is operating as a master, it must not transmit an address that is the same as its slave address. An I<sup>2</sup>C device cannot be master and slave at the same time; if this is attempted, the results are boundedly undefined.

Only the slave with a calling address that matches the one transmitted by the master responds by returning an acknowledge bit (pulling the SDA signal low at the 9th clock) as shown in Figure 10-20. If no slave acknowledges the address, the master should generate a STOP condition or a repeated START condition.

When slave addressing is successful (and SCL returns to zero), the data transfer can proceed on a byte-to-byte basis in the direction specified by the R/W\_B bit sent by the calling master.

The I<sup>2</sup>C module responds to a general call (broadcast) command when I2CCR[BCST] is set. A broadcast address is always zero; however the I<sup>2</sup>C module does not check the R/W\_B bit. The second byte of the broadcast message is the master address. Because the second byte is automatically acknowledged by hardware, the receiver device software must verify that the broadcast message is intended for itself by reading the second byte of the message. If the master address is for another receiver device and the third byte is a write command, software can ignore the third byte during the broadcast. If the master address is for another receiver device and the third byte is a read command, software must write 0xFF to I2CDR with I2CCR[TXAK] = 1, so that it does not interfere with the data written from the addressed device.

Each data byte is 8 bits long. Data bits can be changed only while SCL is low and must be held stable while SCL is high, as shown in Figure 10-20. There is one clock pulse on SCL for each data bit, and the most significant bit (msb) is transmitted first. Each byte of data must be followed by an acknowledge bit, which is signaled from the receiving device by pulling the SDA line low at the 9th clock. Therefore, one complete data byte transfer takes 9 clock pulses. Several bytes can be transferred during a data transfer session.

If the slave receiver does not acknowledge the master, the SDA line must be left high by the slave. The master can then generate a stop condition to abort the data transfer or a START condition (repeated START) to begin a new calling.

If the master receiver does not acknowledge the slave transmitter after a byte of transmission, the slave interprets that the end-of-data has been reached. Then the slave releases the SDA line for the master to generate a STOP or a START condition.

### 10.5.1.3 Repeated START condition

Figure 10-20 shows a repeated START condition, which is generated without a STOP condition that can terminate the previous transfer. The master uses this method to communicate with another slave or with the same slave in a different mode (transmit/receive mode) without releasing the bus.

#### 10.5.1.4 STOP condition

The master can terminate the transfer by generating a STOP condition to free the bus.

A STOP condition is defined as a low-to-high transition of the SDA signal while SCL is high. For more information, see Figure 10-20. Note that a master can generate a STOP even if the slave has transmitted an acknowledge bit, at which point the slave must release the bus. The STOP condition is initiated by a software write that clears I2CCR[MSTA].

As described in Repeated START condition, the master can generate a START condition followed by a calling address without generating a STOP condition for the previous transfer. This is called a repeated START condition.

### 10.5.1.5 Protocol implementation details

The following sections provide details about how aspects of the protocol are implemented in this I<sup>2</sup>C module.

### 10.5.1.5.1 Transaction monitoring-implementation details

The different conditions of the I<sup>2</sup>C data transfers are monitored as follows:

- START conditions are detected when an SDA fall occurs while SCL is high.
- STOP conditions are detected when an SDA rise occurs while SCL is high.
- Data transfers in progress are canceled when a STOP condition is detected or if there
  is a slave address mismatch. Cancellation of data transactions resets the clock
  module.
- The bus is detected to be busy upon the detection of a START condition, and idle upon the detection of a STOP condition.

# 10.5.1.5.2 Control transfer-implementation details

The I<sup>2</sup>C module contains logic that controls the output to the serial data (SDA) and serial clock (SCL) lines of the I<sup>2</sup>C.

#### **Functional description**

The SCL output is pulled low as determined by the internal clock generated in the clock module. The SDA output can only change at the midpoint of a low cycle of the SCL, unless it is performing a START, STOP, or restart condition. Otherwise, the SDA output is held constant.

The SDA signal is pulled low when one or more of the following conditions are true in either master or slave mode:

- Master mode
  - Data bit (transmit)
  - Ack bit (receive)
  - START condition
  - STOP condition
  - Restart condition
- Slave mode
  - Acknowledging address match
  - Data bit (transmit)
  - Ack bit (receive)

The SCL signal corresponds to the internal SCL signal when one or more of the following conditions are true in either master or slave mode:

- Master mode
  - Bus owner
  - Lost arbitration
  - START condition
  - STOP condition
  - Restart condition begin
  - Restart condition end
- Slave mode
  - Address cycle
  - Transmit cycle
  - Ack cycle

# 10.5.1.6 Address compare-implementation details

Address compare block determines if a slave has been properly addressed, either by its slave address or by the general broadcast address (which addresses all slaves).

The three performed address comparisons are described as follows:

• Whether a broadcast message has been received, to update the I2CSR

- Whether the module has been addressed as a slave, to update the I2CSR and to generate an interrupt
- If the address transmitted by the current master matches the general broadcast address

# 10.5.2 Arbitration procedure

The I<sup>2</sup>C interface is a true multiple-master bus that allows more than one master device to be connected on it.

If two or more masters simultaneously try to control the bus, each master's clock synchronization procedure (including the I<sup>2</sup>C module) determines the bus clock-the low period is equal to the longest clock low period and the high is equal to the shortest one among the masters. A bus master loses arbitration if it transmits a logic 1 on SDA while another master transmits a logic 0. The losing masters immediately switch to slave-receive mode and stop driving the SDA line. In this case, the transition from master to slave mode does not generate a STOP condition. Meanwhile, the I<sup>2</sup>C unit sets the I2CSR[MAL] status bit to indicate the loss of arbitration and, as a slave, services the transaction if it is directed to itself.

If the I<sup>2</sup>C module is enabled in the middle of an ongoing byte transfer, the interface behaves as follows:

- Slave mode-The I<sup>2</sup>C module ignores the current transfer on the bus and starts operating whenever a subsequent START condition is detected.
- Master mode-The I<sup>2</sup>C module cannot tell whether the bus is busy; therefore, if a START condition is initiated, the current bus cycle can be corrupted. This ultimately results in the current bus master of the I<sup>2</sup>C interface losing arbitration, after which bus operations return to normal.

#### 10.5.2.1 Arbitration control

The arbitration control block controls the arbitration procedure of the master mode.

A loss of arbitration occurs whenever the master detects a 0 on the external SDA line while attempting to drive a 1, tries to generate a START or restart at an inappropriate time, or detects an unexpected STOP request on the line.

In master mode, arbitration by the master is lost (and I2CSR[MAL] is set) under the following conditions:

#### **Functional description**

- SDA samples low when the master drives high during an address or data-transmit cycle (transmit).
- SDA samples low when the master drives high during a data-receive cycle of the acknowledge (Ack) bit (receive).
- A START condition is attempted when the bus is busy.
- A repeated START condition is requested in slave mode.
- A start condition is attempted when the requesting device is not the bus owner
- Unexpected STOP condition detected

Note that the I<sup>2</sup>C module does not automatically retry a failed transfer attempt.

# 10.5.3 Handshaking

The clock synchronization mechanism can be used as a handshake in data transfer.

Slave devices can hold SCL low after completion of a 1-byte transfer (9 bits). In such cases, it halts the bus clock and forces the master clock into wait states until the slave releases the SCL line.

#### 10.5.4 Clock control

The clock control block handles requests from the clock signal for transferring and controlling data for multiple tasks.

A 9-cycle data transfer clock is requested for the following conditions:

- Master mode
  - Transmit slave address after START condition
  - Transmit slave address after restart condition
  - Transmit data
  - Receive data
- Slave mode
  - Transmit data
  - Receive data
  - Receive slave address after START or restart condition

### 10.5.4.1 Clock synchronization

Due to the wire AND logic on the SCL line, a high-to-low transition on the SCL line affects all devices connected on the bus.

The devices begin counting their low period when the master drives the SCL line low. After a device has driven SCL low, it holds the SCL line low until the clock high state is reached. However, the change of low-to-high in a device clock may not change the state of the SCL line if another device is still within its low period. Therefore, the synchronized clock signal, SCL, is held low by the device with the longest low period. Devices with shorter low periods enter a high wait state during this time. When all devices concerned have counted off their low period, the synchronized SCL line is released and pulled high. Then there is no difference between the devices' clocks and the state of the SCL line, and all the devices begin counting their high periods. The first device to complete its high period pulls the SCL line low again.

### 10.5.4.2 Input synchronization and digital filter

The following sections describes the synchronizing of the input signals and the filtering of the SCL and SDA lines in detail.

### 10.5.4.2.1 Input signal synchronization

The input synchronization block synchronizes the input SCL and SDA signals to the system clock and detects transitions of these signals.

### 10.5.4.2.2 Filtering of SCL and SDA lines

The SCL and SDA inputs are filtered to eliminate noise.

Three consecutive samples of the SCL and SDA lines are compared to a pre-determined sampling rate. If they are all high, the output of the filter is high. If they are all low, the output is low. If they are any combination of highs and lows, the output is whatever the value of the line was in the previous clock cycle.

The sampling rate is equal to a binary value stored in the frequency register I2CDFSRR. The duration of the sampling cycle is controlled by a down counter. This allows a software write to the frequency register to control the filtered sampling rate.

### 10.5.4.3 Clock stretching

Slaves can use the clock synchronization mechanism to slow down the transfer bit rate.

After the master has driven the SCL line low, the slave can drive SCL low for the required period and then release it. If the slave SCL low period is greater than the master SCL low period, then the resulting SCL bus signal low period is stretched.

# 10.5.5 Boot sequencer mode

If boot sequencer mode is selected on POR (by the settings on the cfg\_boot\_seq[0:1] reset configuration signals, as described in Boot sequencer configuration), the I<sup>2</sup>C1 module communicates with one or more EEPROMs through the I<sup>2</sup>C interface on IIC1\_SCL and IIC1\_SDA. The boot sequencer accesses the I<sup>2</sup>C1 serial ROM device at a serial bit clock frequency equal to the platform ( CCB) clock frequency divided by 2560. The EEPROM(s) can be programmed to initialize one or more configuration registers of this integrated device.

If the boot sequencer is enabled for normal I<sup>2</sup>C addressing mode, the I<sup>2</sup>C interface initiates the following sequence during reset:

- 1. Generate RESET sequence (START then 9 SCL cycles) to the EEPROM twice. This clears any transactions that may have been in progress prior to the reset.
- 2. Generate START
- 3. Transmit 0xA0 which is the 7-bit calling address (0b101\_0000) with a write command appended (0 as the least significant bit).
- 4. Transmit 0x00 which is the 8-bit starting address
- 5. Generate a repeated START
- 6. Transmit 0xA1 which is the 7-bit calling address (0b101\_0000) with a read command appended (1 as the least significant bit).
- 7. Receive 256 bytes of data from the EEPROM (unless the CONT bit is cleared in the data structure).
- 8. Generate a repeated START
- 9. Transmit 0xA2 which is the 7-bit calling address of the second target (0b101\_0001) with a write command appended (0 as the least significant bit).
- 10. Transmit 0x00 which is the 8-bit starting address for the second target.
- 11. Generate a repeated START
- 12. Transmit 0xA3 which is the 7-bit calling address (0b101\_0001) with a read command appended (1 as the least significant bit).
- 13. Receive another 256 bytes of data from the second EEPROM (unless the CONT bit is cleared in the data structure).

The sequence repeats with successive targets until the CONT bit in the data structure is cleared and the CRC check is executed. If the last register is not detected (that is, the CONT bit is never cleared) before wrapping back to the first address, an error condition is detected, causing the device to hang and the HRESET\_REQ\_B signal to assert externally. The I<sup>2</sup>C module continues to read from the EEPROM(s) as long as the

continue (CONT) bit is set in the EEPROM(s). The CONT bit resides in the address/ attributes field that is transferred from the EEPROM, as described in EEPROM calling address. There should be no other I<sup>2</sup>C traffic when the boot sequencer is active.

The boot sequencer mode also supports an extension of the standard I<sup>2</sup>C interface that uses more address bits to allow for EEPROM devices that have more than 256 bytes, and this extended addressing mode is selectable during POR with a different encoding on the cfg\_boot\_seq[0:1] reset configuration signals. In this mode, only one EEPROM device may be used, and the maximum number of registers is limited by the size of the EEPROM. If the boot sequencer is enabled for extended I<sup>2</sup>C addressing mode, the I<sup>2</sup>C interface initiates the following sequence during reset:

- 1. Generate RESET sequence (START then 9 SCL cycles) to the EEPROM twice. This clears any transactions that may have been in progress prior to the reset.
- 2. Generate START
- 3. Transmit 0xA0 which is the 7-bit calling address (0b101\_0000) with a write command appended (0 as the least significant bit).
- 4. Transmit 0x00 which is the high-order starting address
- 5. Transmit 0x00 which is the low-order starting address
- 6. Generate a repeated START
- 7. Transmit 0xA1 which is the 7-bit calling address (0b101\_0000) with a read command appended (1 as the least significant bit).
- 8. Receive data continuously from the EEPROM until the CONT bit is cleared and the CRC check is executed. See EEPROM data format, for more information.

Note that as described in Boot sequencer configuration, the default value for the cfg\_boot\_seq[0:1] reset configuration pins is 0b11, which corresponds to the I<sup>2</sup>C boot sequencer being disabled at power-up.

# 10.5.5.1 EEPROM calling address

The device uses 0b101\_0000 for the EEPROM calling address.

The first EEPROM to be addressed must be programmed to respond to this address, or an error is generated. If more EEPROMs are used, they are addressed in sequential order.

#### 10.5.5.2 EEPROM data format

The I<sup>2</sup>C module expects that a particular data format be used for data in the EEPROM.

#### **Functional description**

A preamble should be the first 3 bytes programmed into the EEPROM. It should have a value of 0xAA\_55AA. The I<sup>2</sup>C module checks to ensure that this preamble is correctly detected before proceeding further. Following the preamble, there should be a series of configuration registers (known as register preloads) programmed into the EEPROM. Each configuration register should be programmed according to a particular format, as shown in Table 10-21. The first 3 bytes hold the attributes and address offset, as follows. The attributes contained are alternate configuration space (ACS), byte enables, and continue (CONT). The boot sequencer expects the address offset to be a 32-bit (word) offset, that is, the 2 low-order bits are not included in the boot sequencer command. For example, to access LAWBAR0 (byte offset of 0x00C08), the boot sequencer ADDR[0:17] should be set to 0x00302.

After the first 3 bytes, 4 bytes of data should hold the desired value of the configuration register, regardless of the size of the transaction. Byte enables should be asserted for any byte that is written to the configuration register, and they should be asserted contiguously, creating a 1-, 2-, or 4-byte write to a register. The boot sequencer assumes that a big-endian address is stored in the EEPROM. In addition, byte enable bit 0 (bit 1 of the byte) corresponds to the most-significant byte of data (data[0:7]), and byte enable bit 3 (bit 4 of the byte) corresponds to the LSB of data (data[24:31]).

By setting ACS, an alternate configuration space address is prepended to the write request from the boot sequencer. Otherwise, CCSRBAR is prepended to the EEPROM address.

If CONT is cleared, the first 3 bytes, including ACS, the byte enables, and the address, must also be cleared. Also, the data contains the final cyclic redundancy check (CRC). A CRC-32 algorithm is used to check the integrity of the data. The polynomial used is:

$$1 + x^{1} + x^{2} + x^{4} + x^{5} + x^{7} + x^{8} + x^{10} + x^{11} + x^{12} + x^{16} + x^{22} + x^{23} + x^{26} + x^{32}$$

CRC values are calculated using the above polynomial with a start value of 0xFFFF\_FFFF and an XOR with 0x0000\_0000. The CRC should cover all bytes stored in the EEPROM prior to the CRC. This includes the preamble, all register preloads, and the first 3 bytes of the last 7-byte preload (which should be all zeros). If a preamble or CRC fail is detected, the device hangs and the external HRESET\_REQ\_B signal asserts. If there is a preamble fail, the boot sequencer may continue to pull I<sup>2</sup>C pins low until a hard reset occurs.

Table 10-21. EEPROM data format for one register preload command

| 0           | 1       |  |  | 4 | 5    | 6         | 7 |  |
|-------------|---------|--|--|---|------|-----------|---|--|
| ACS         | BYTE_EN |  |  |   | CONT | ADDR[0-1] |   |  |
| ADDR[2-9]   |         |  |  |   |      |           |   |  |
| ADDR[10-17] |         |  |  |   |      |           |   |  |

Table continues on the next page...

Table 10-21. EEPROM data format for one register preload command (continued)

| DATA[0-7]   |
|-------------|
| DATA[8-15]  |
| DATA[16-23] |
| DATA[24-31] |

Table 10-22 shows an example of the EEPROM contents, including the preamble, data format, and CRC.

**Table 10-22. EEPROM contents** 

| 0         | 1 1                 | 2      | 3                                       | 4                               | 5 | 6       | 7                    |                     |
|-----------|---------------------|--------|-----------------------------------------|---------------------------------|---|---------|----------------------|---------------------|
| 1         | 0                   | 1      | 0                                       | 1                               | 0 | 1       | 0                    | Preamble            |
| 0         | 1                   | 0      | 1                                       | 0                               | 1 | 0       | 1                    |                     |
| 1         | 0                   | 1      | 0                                       | 1                               | 0 | 1       | 0                    |                     |
| ACS       |                     | BYT    | E_EN                                    |                                 | 1 | ADDI    | R[0-1]               | First configuration |
| ADDR[2-9] |                     |        |                                         |                                 |   |         |                      | Preload command     |
|           |                     |        |                                         |                                 |   |         |                      |                     |
|           |                     |        | DATA[                                   | 0-7]                            |   |         |                      |                     |
|           |                     |        | DATA[8                                  | B-15]                           |   |         |                      |                     |
|           |                     |        | DATA[1                                  | 6-23]                           |   |         |                      |                     |
|           |                     |        | DATA[2                                  | 4-31]                           |   |         |                      |                     |
| ACS       | BYTE_EN 1 ADDR[0-1] |        |                                         |                                 |   |         | Second configuration |                     |
|           |                     |        | ADDR[                                   | 2-9]                            |   |         |                      | Preload command     |
|           |                     |        | ADDR[1                                  | 0-17]                           |   |         |                      |                     |
|           |                     |        | DATA[                                   | 0-7]                            |   |         |                      |                     |
|           |                     |        | DATA[8                                  |                                 |   |         |                      |                     |
|           |                     |        | DATA[1                                  | 6-23]                           |   |         |                      |                     |
|           |                     |        | DATA[2                                  | 4-31]                           |   |         |                      |                     |
|           |                     |        |                                         |                                 | • |         |                      |                     |
|           |                     |        |                                         |                                 |   |         |                      |                     |
|           |                     |        |                                         |                                 |   |         |                      |                     |
|           |                     |        |                                         |                                 | 1 | الالالا | ₹[0-1]               | Last configuration  |
| ACS       |                     | BYT    | E_EN                                    |                                 | ' | וטטא    | וו-טור               |                     |
| ACS       |                     | BYT    | E_EN<br>ADDR[                           | 2-9]                            | ' | ADDI    | 1[0-1]               | Preload command     |
| ACS       |                     | BYT    |                                         |                                 |   | ADDI    | 10-11                | -                   |
| ACS       |                     | ВҮТ    | ADDR[                                   | 0-17]                           | ' | ADDI    | 1[0-1]               | -                   |
| ACS       |                     | ВҮТ    | ADDR[<br>ADDR[1                         | 0-17]<br>0-7]                   | ' | ADDI    | 1[0-1]               | -                   |
| ACS       |                     | BYTI   | ADDR[<br>ADDR[1<br>DATA[                | 0-17]<br>0-7]<br>3-15]          |   | ADDI    | ال-اا                | -                   |
| ACS       |                     | ВҮТ    | ADDR[1<br>ADDR[1<br>DATA[0<br>DATA[8    | 0-17]<br>0-7]<br>3-15]<br>6-23] |   | Abbi    | ٦[٧-١]               | -                   |
| ACS<br>0  | 0                   | 0<br>0 | ADDR[1  ADDR[1  DATA[0  DATA[1  DATA[1] | 0-17]<br>0-7]<br>3-15]<br>6-23] | 0 | 0       | 0                    | -                   |
|           | 0 0                 |        | ADDR[1 ADDR[1 DATA[8 DATA[1] DATA[2     | 0-17]<br>0-7]<br>3-15]<br>6-23] |   |         |                      | Preload command     |

Table continues on the next page...

Table 10-22. EEPROM contents (continued)

| 0          | 1 | 2 | 3 | 4 | 5 | 6 | 7 |                         |
|------------|---|---|---|---|---|---|---|-------------------------|
| CRC[0-7]   |   |   |   |   |   |   |   | Cyclic Redundancy Check |
| CRC[8-15]  |   |   |   |   |   |   |   |                         |
| CRC[16-23] |   |   |   |   |   |   |   |                         |
|            |   |   |   |   |   |   |   |                         |

# 10.6 Initialization/application information

This section describes some programming guidelines recommended for the I<sup>2</sup>C interface. See Figure 10-21 for a recommended flowchart for I<sup>2</sup>C interrupt service routines.

The I<sup>2</sup>C registers in this chapter are shown in big-endian format. If the system is in little-endian mode, software must swap the bytes appropriately. This appropriate byte swapping is needed as I<sup>2</sup>C registers are byte registers. Also, an **msync** assembly instruction must be executed after each I<sup>2</sup>C register read/write access to guarantee in-order execution.

The I<sup>2</sup>C controller does not guarantee its recovery from all illegal I<sup>2</sup>C bus activity. In addition, a malfunctioning device may hold the bus captive. A good programming practice is for software to rely on a watchdog timer to help recover from I<sup>2</sup>C bus hangs. The recovery routine should also handle the case when the status bits returned after an interrupt are not consistent with what was expected due to illegal I<sup>2</sup>C bus protocol behavior.

# 10.6.1 Initialization sequence

A hard reset initializes all the I<sup>2</sup>C registers to their default states.

The following initialization sequence initializes the  $I^2C$  unit:

- 1. All I<sup>2</sup>C registers must be located in a cache-inhibited page.
- 2. Update I2CFDR[FDR] and select the required division ratio to obtain the SCL frequency from the CCB (platform) clock. Note that the platform frequency must first be divided by two; see I2C frequency divider register (I2C\_I2CFDR), for more details.
- 3. Update I2CADR to define the slave address for this device.
- 4. Modify I2CCR to select master/slave mode, transmit/receive mode, and interruptenable or disable.
- 5. Set the I2CCR[MEN] to enable the  $I^2C$  interface.

### 10.6.2 Generation of START

After initialization, the following sequence can be used to generate START:

- 1. If the device is connected to a multimaster I<sup>2</sup>C system, test the state of I2CSR[MBB] to check whether the serial bus is free (I2CSR[MBB] = 0) before switching to master mode.
- 2. Select master mode (set I2CCR[MSTA]) to transmit serial data and select transmit mode (set I2CCR[MTX]) for the address cycle.
- 3. Write the slave address being called into I2CDR. The data written to I2CDR[0-6] comprises the slave calling address. I2CCR[MTX] indicates the direction of transfer (transmit/receive) required from the slave.

The scenario above assumes that the  $I^2C$  interrupt bit (I2CSR[MIF]) is cleared. If MIF is set at any time, an  $I^2C$  interrupt is generated (provided interrupt reporting is enabled with I2CCR[MIEN] =1) so that the  $I^2C$  interrupt handler can handle the interrupt. Note that the interrupts for  $I^2C1$  and  $I^2C2$  are combined into one interrupt, which is sourced by the dual  $I^2C$  controller.

# 10.6.3 Post-transfer software response

Transmission or reception of a byte automatically sets the data transferring bit (I2CSR[MCF]), which indicates that one byte has been transferred.

The I<sup>2</sup>C interrupt bit (I2CSR[MIF]) is also set and an interrupt is generated to the processor if the interrupt function is enabled during the initialization sequence (I2CCR[MIEN] is set). In the interrupt handler, software must take the following steps:

- 1. Clear I2CSR[MIF].
- 2. Read the contents of the I<sup>2</sup>C data register (I2CDR) in receive mode or write to I2CDR in transmit mode. Note that this causes I2CSR[MCF] to be cleared. See Interrupt service routine flowchart.

When an interrupt occurs at the end of the address cycle, the master remains in transmit mode. If master receive mode is required, I2CCR[MTX] must be toggled at this stage. See Interrupt service routine flowchart.

If the interrupt function is disabled, software can service the I2CDR in the main program by monitoring I2CSR[MIF]. In this case, I2CSR[MIF] must be polled rather than I2CSR[MCF] because MCF behaves differently when arbitration is lost. Note that

#### Initialization/application information

interrupt or other bus conditions may be detected before the I<sup>2</sup>C signals have time to settle. Thus, when polling I2CSR[MIF] (or any other I2CSR bits), software delays may be needed in order to give the I<sup>2</sup>C signals sufficient time to settle.

During slave-mode address cycles (I2CSR[MAAS] is set), I2CSR[SRW] should be read to determine the direction of the subsequent transfer and I2CCR[MTX] should be programmed accordingly. For slave-mode data cycles (MAAS is cleared), I2CSR[SRW] is not valid and I2CCR[MTX] must be read to determine the direction of the current transfer. See Interrupt service routine flowchart, for more details.

#### 10.6.4 Generation of STOP

A data transfer ends with a STOP condition generated by the master device.

A master transmitter can generate a STOP condition after all the data has been transmitted.

If a master receiver wants to terminate a data transfer, it must inform the slave transmitter by not acknowledging the last byte of data (by setting the transmit acknowledge bit (I2CCR[TXAK])) before reading the next-to-last byte of data. At this time, the next-to-last byte of data has already been transferred on the I<sup>2</sup>C interface, so the last byte does not receive the data acknowledge (because I2CCR[TXAK] is set). Before the interrupt service routine reads the last byte of data, a STOP condition must first be generated.

I2CCR[TXAK] must be set before allowing the I<sup>2</sup>C module to receive the last data byte on the I<sup>2</sup>C bus. Eventually, I2CCR[TXAK] must be cleared again for subsequent I<sup>2</sup>C transactions. This can be accomplished when setting up the I2CCR for the next transfer.

# 10.6.5 Generation of repeated START

At the end of a data transfer, if the master still wants to communicate on the bus, it can generate another START condition followed by another slave address without first generating a STOP condition.

This is accomplished by setting I2CCR[RSTA].

### 10.6.6 Generation of SCL when SDA low

It is sometimes necessary to force the I<sup>2</sup>C module to become the I<sup>2</sup>C bus master out of reset and drive SCL (even though SDA may already be driven, which indicates that the bus is busy).

This can occur when a system reset does not cause all I<sup>2</sup>C devices to be reset. Thus, SDA can be driven low by another I<sup>2</sup>C device while this I<sup>2</sup>C module is coming out of reset and stays low indefinitely. The following procedure can be used to force this I<sup>2</sup>C module to generate SCL so that the device driving SDA can finish its transaction:

- 1. Disable the I<sup>2</sup>C module and set the master bit by setting I2CCR to 0x20
- 2. Enable the  $I^2C$  module by setting I2CCR to 0xA0
- 3. Read the I2CDR
- 4. Return the  $I^2C$  module to slave mode by setting I2CCR to 0x80

# 10.6.7 Slave mode interrupt service routine

In the slave interrupt service routine, the module addressed as a slave should be tested to check if a calling of its own address has been received.

If I2CSR[MAAS] is set, software should set the transmit/receive mode select bit (I2CCR[MTX]) according to the R/W\_B command bit (I2CSR[SRW]). Writing to I2CCR clears MAAS automatically. MAAS is read as set only in the interrupt handler at the end of that address cycle where an address match occurred; interrupts resulting from subsequent data transfers clear MAAS. A data transfer can then be initiated by writing to I2CDR for slave transmits or dummy reading from I2CDR in slave-receive mode. The slave drives SCL low between byte transfers. SCL is released when the I2CDR is accessed in the required mode.

# 10.6.7.1 Slave transmitter and received acknowledge

In the slave transmitter routine, the received acknowledge bit (I2CSR[RXAK]) must be tested before sending the next byte of data.

The master signals an end-of-data by not acknowledging the data transfer from the slave. When no acknowledge is received (I2CSR[RXAK] is set), the slave transmitter interrupt routine must clear I2CCR[MTX] to switch the slave from transmitter to receiver mode. A dummy read of I2CDR then releases SCL so that the master can generate a STOP condition. See Interrupt service routine flowchart.

### 10.6.7.2 Loss of arbitration and forcing of slave mode

When a master loses arbitration the following conditions all occur:

• I2CSR[MAL] is set

#### Initialization/application information

- I2CCR[MSTA] is cleared (changing the master to slave mode)
- An interrupt occurs (if enabled) at the falling edge of the 9th clock of this transfer

Thus, the slave interrupt service routine should first test I2CSR[MAL] and software should clear it if it is set. See Arbitration control, for more information.

# 10.6.8 Interrupt service routine flowchart

The following figure shows an example algorithm for an I<sup>2</sup>C interrupt service routine.

Deviation from the flowchart may result in unpredictable I<sup>2</sup>C bus behavior. However, in the slave receive mode the interrupt service routine may need to set I2CCR[TXAK] when the next-to-last byte is to be accepted. It is recommended that an **msync** instruction follow each I<sup>2</sup>C register read or write to guarantee in-order instruction execution.



Figure 00-22 In Hagament & 18 Ce isstement esservitae una justime of lowed 1 art

Initialization/application information

# Chapter 11 DUART

This chapter describes the dual universal asynchronous receiver/transmitters (DUART). It describes the functional operation, the initialization sequence, and the programming details for the DUART registers and features.

## 11.1 Introduction

This chapter describes the dual universal asynchronous receiver/transmitters (DUART). It describes the functional operation, the initialization sequence, and the programming details for the DUART registers and features.

## 11.1.1 Overview

The DUART consists of two universal asynchronous receiver/transmitters (UARTs).

The UARTs act independently; all references to UART refer to one of these receiver/transmitters. Each UART is clocked by the platform (CCB) clock. The DUART programming model is compatible with the PC16552D.

The UART interface is point to point, meaning that only two UART devices are attached to the connecting signals. As shown in Figure 11-1, each UART module consists of the following:

- Receive and transmit buffers
- Clear to send (CTS\_B) input port and request to send (RTS\_B) output port for data flow control
- 16-bit counter for baud rate generation
- Interrupt control logic



Figure 11-1. UART block diagram

#### 11.1.1.1 Features

The DUART includes these distinctive features:

- Full-duplex operation
- Programming model compatible with original PC16450 UART and PC16550D (improved version of PC16450 that also operates in FIFO mode)
- PC16450 register reset values
- FIFO mode for both transmitter and receiver, providing 16-byte FIFOs
- Serial data encapsulation and decapsulation with standard asynchronous communication bits (START, STOP, and parity)
- Maskable transmit, receive, line status, and modem status interrupts
- Software-programmable baud generators that divide the platform clock by 1 to  $(2^{16} 1)$  and generate a 16x clock for the transmitter and receiver engines
- Clear to send (CTS\_B and ready to send (RTS\_B) modem control functions
- Software-selectable serial interface data format (data length, parity, 1/1.5/2 STOP bit, baud rate)
- Line and modem status registers
- Line-break detection and generation

- Internal diagnostic support, local loopback, and break functions
- Prioritized interrupt reporting
- Overrun, parity, and framing error detection

## 11.1.1.2 Modes of operation

The communication channel provides a full-duplex asynchronous receiver and transmitter using an operating frequency derived from the platform clock.

The transmitter accepts parallel data from a write to the transmitter holding register (UTHR). In FIFO mode, the data is placed directly into an internal transmitter shift register of the transmitter FIFO. The transmitter converts the data to a serial bit stream inserting the appropriate start, stop, and optional parity bits. Finally, it outputs a composite serial data stream on the channel transmitter serial data output signal (SOUT). The transmitter status may be polled or interrupt driven.

The receiver accepts serial data bits on the channel receiver serial data input signal (SIN), converts it to parallel format, checks for a start bit, parity (if any), stop bits, and transfers the assembled character (with start, stop, parity bits removed) from the receiver buffer (or FIFO) in response to a read of the UART's receiver buffer register (URBR). The receiver status may be polled or interrupt driven.

# 11.2 DUART external signal descriptions

The DUART signals are described in Table 11-1. Note that although the actual device signal names are prepended with the UART\_ prefix as shown in the table, the functional (abbreviated) signal names are often used throughout this chapter.

Table 11-1. DUART signals-detailed signal descriptions

| Signal        | I/O |               | Description                                                                                                                                                    |  |
|---------------|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| UART_SIN[0:1] | I   |               | ial data in. Data is received on the receivers of UART0 and UART1 through the respective serial a input signal, with the least-significant bit received first. |  |
|               |     | State meaning |                                                                                                                                                                |  |
|               |     | Timing        | Assertion/Negation-An internal logic sample signal, <i>rxcnt</i> , uses the frequency of the baud-rate generator to sample the data on SIN.                    |  |

Table 11-1. DUART signals-detailed signal descriptions (continued)

| Signal         | I/O |               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|----------------|-----|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| UART_SOUT[0:1] | 0   | when the      | rial data out. The serial data output signals for the UART0 and UART1 are set ('mark' condition<br>en the transmitter is disabled, idle, or operating in the local loopback mode. Data is shifted out<br>se signals, with the least significant bit transmitted first.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|                |     | State meaning | Asserted/Negated-Represents the data being transmitted on the respective UART interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|                |     | Timing        | Assertion/Negation- An internal logic sample signal, <i>rxcnt</i> , uses the frequency of the baud-rate generator to update and drive the data on SOUT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| UART_CTS_B[0:1 | I   | respective    | end. These active-low inputs are the clear-to-send inputs. They are connected to the RTS_B outputs of the other UART devices on the bus. They can be programmed to an interrupt on change-of-state of the signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                |     | State meaning | - I a constant a general respective and a constant a co |  |  |  |
|                |     | Timing        | Assertion/Negation-Sampled at the rising edge of every platform clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| UART_RTS_B[0:1 | 0   | automatic     | o send. UART_RTS_Bx are active-low output signals that can be programmed to be ally negated and asserted by either the receiver or transmitter. When connected to the end (CTS_B) input of a transmitter, this signal can be used to control serial data flow.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                |     | State meaning | Asserted/Negated-Represents the data being transmitted on the respective UART interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|                |     | Timing        | Assertion/Negation-Updated and driven at the rising edge of every platform clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |

# 11.3 DUART memory map/register definition

The table below lists the DUART registers and their offsets. It lists the address, name, and a cross-reference to the complete description of each register. Note that the full register address is comprised of CCSRBAR together with the block base address and offset listed in the table below.

There are two complete sets of DUART registers (one for each UART). The two UARTs on the device are identical, except that the registers for each UART are located at different offsets. Throughout this chapter, the registers are described by a singular acronym: for example, LCR represents the line control register for either UART0 or UART1.

The registers in each UART interface are used for configuration, control, and status. The divisor latch access bit, ULCR[DLAB], is used to access the divisor latch least- and most-significant bit registers and the alternate function register. Refer to Line Control Registers (DUART\_ULCRn), for more information on ULCR[DLAB].

All the DUART registers are one-byte wide. Reads and writes to these registers must be byte-wide operations. The table below provides a register summary with references to the section and page that contains detailed information about each register. Undefined byte address spaces within offset 0x000-0xFFF are reserved.

## **DUART** memory map

| Offset<br>address<br>(hex) | Register name                                          |   | Access | Reset value | Section/<br>page |
|----------------------------|--------------------------------------------------------|---|--------|-------------|------------------|
| 4500                       | Receiver Buffer Registers (DUART_URBR1)                | 8 | R      | 00h         | 11.3.1/512       |
| 4500                       | Transmitter Holding Registers (DUART_UTHR1)            | 8 | W      | 00h         | 11.3.2/512       |
| 4500                       | Divisor Least Significant Byte Registers (DUART_UDLB1) | 8 | R/W    | 00h         | 11.3.3/513       |
| 4501                       | Divisor Most Significant Byte Registers (DUART_UDMB1)  | 8 | R/W    | 00h         | 11.3.4/514       |
| 4501                       | Interrupt Enable Register (DUART_UIER1)                | 8 | R/W    | 00h         | 11.3.5/515       |
| 4502                       | Interrupt ID Registers (DUART_UIIR1)                   | 8 | R      | 01h         | 11.3.6/516       |
| 4502                       | FIFO Control Registers (DUART_UFCR1)                   | 8 | W      | 00h         | 11.3.7/517       |
| 4502                       | Alternate Function Registers (DUART_UAFR1)             | 8 | R/W    | 00h         | 11.3.8/519       |
| 4503                       | Line Control Registers (DUART_ULCR1)                   | 8 | R/W    | 00h         | 11.3.9/519       |
| 4504                       | Modem Control Registers (DUART_UMCR1)                  | 8 | R/W    | 00h         | 11.3.10/<br>521  |
| 4505                       | Line Status Registers (DUART_ULSR1)                    | 8 | R      | 60h         | 11.3.11/<br>522  |
| 4506                       | Modem Status Registers (DUART_UMSR1)                   | 8 | R      | 00h         | 11.3.12/<br>523  |
| 4507                       | Scratch Registers (DUART_USCR1)                        |   | R/W    | 00h         | 11.3.13/<br>524  |
| 4510                       | DMA Status Registers (DUART_UDSR1)                     | 8 | R      | 01h         | 11.3.14/<br>524  |
| 4600                       | Receiver Buffer Registers (DUART_URBR2)                | 8 | R      | 00h         | 11.3.1/512       |
| 4600                       | Transmitter Holding Registers (DUART_UTHR2)            | 8 | W      | 00h         | 11.3.2/512       |
| 4600                       | Divisor Least Significant Byte Registers (DUART_UDLB2) | 8 | R/W    | 00h         | 11.3.3/513       |
| 4601                       | Divisor Most Significant Byte Registers (DUART_UDMB2)  | 8 | R/W    | 00h         | 11.3.4/514       |
| 4601                       | Interrupt Enable Register (DUART_UIER2)                | 8 | R/W    | 00h         | 11.3.5/515       |
| 4602                       | Interrupt ID Registers (DUART_UIIR2)                   | 8 | R      | 01h         | 11.3.6/516       |
| 4602                       | FIFO Control Registers (DUART_UFCR2)                   | 8 | W      | 00h         | 11.3.7/517       |
| 4602                       | Alternate Function Registers (DUART_UAFR2)             | 8 | R/W    | 00h         | 11.3.8/519       |
| 4603                       | Line Control Registers (DUART_ULCR2)                   | 8 | R/W    | 00h         | 11.3.9/519       |
| 4604                       | Modem Control Registers (DUART_UMCR2)                  | 8 | R/W    | 00h         | 11.3.10/<br>521  |
| 4605                       | Line Status Registers (DUART_ULSR2)                    | 8 | R      | 60h         | 11.3.11/<br>522  |
| 4606                       | Modem Status Registers (DUART_UMSR2)                   | 8 | R      | 00h         | 11.3.12/<br>523  |
| 4607                       | Scratch Registers (DUART_USCR2)                        | 8 | R/W    | 00h         | 11.3.13/<br>524  |

### **DUART memory map (continued)**

| Offset<br>address<br>(hex) | Register name                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------|--------------------|--------|-------------|------------------|
| 4610                       | DMA Status Registers (DUART_UDSR2) | 8                  | R      | 01h         | 11.3.14/<br>524  |

# 11.3.1 Receiver Buffer Registers (DUART\_URBRn)

This register is accessible when ULCR[DLAB] = 0.

These registers contain the data received from the transmitter on the UART buses. In FIFO mode, when read, they return the first byte received. For FIFO status information, refer to the UDSR[RXRDY] description.

Except for the case when there is an overrun, URBR returns the data in the order it was received from the transmitter. Refer to the ULSR[OE] description, Line Status Registers (DUART\_ULSRn). Note that these registers have same offset as the UTHRs.



| Field       | Description                                                    |
|-------------|----------------------------------------------------------------|
| 0–7<br>DATA | Data received from the transmitter on the UART bus (read only) |

# 11.3.2 Transmitter Holding Registers (DUART\_UTHRn)

This register is accessible when ULCR[DLAB] = 0.

A write to these 8-bit registers causes the UART devices to transfer 5-8 data bits on the UART bus in the format set up in the ULCR (line control register). In FIFO mode, data written to UTHR is placed into the FIFO. The data written to UTHR is the data sent onto the UART bus, and the first byte written to UTHR is the first byte onto the bus. UDSR[TXRDY\_B] indicates when the FIFO is full. Refer to the tables in DMA Status Registers (DUART\_UDSRn) for more details.

Address: 4000h base + 500h offset + (256d × i), where i=0d to 1d



**DUART\_UTHR***n* field descriptions

|   | Field       | Description                               |
|---|-------------|-------------------------------------------|
| Ī | 0–7<br>DATA | Data that is written to UTHR (write only) |

# 11.3.3 Divisor Least Significant Byte Registers (DUART\_UDLBn)

This register is accessible when ULCR[DLAB] = 1.

The divisor least significant byte register (UDLB) is concatenated with the divisor most significant byte register (UDMB) to create the divisor used to divide the input clock into the DUART. The output frequency of the baud generator is 16 times the baud rate; therefore the desired baud rate = platform clock frequency  $\div$  (16 x [UDMB||UDLB]). Equivalently, [UDMB||UDLB:0b0000] = platform clock frequency  $\div$  desired baud rate. Baud rates that can be generated by specific input clock frequencies are shown in the table below.

The following table shows examples of baud rate generation based on common input clock frequencies. Many other target baud rates are also possible. Note that because only integer values can be used as divisors, the actual baud rate differs slightly from the desired (target) baud rate; for this reason, both target and actual baud rates are given, along with the percentage of error.

**Table 11-7. Baud Rate Examples** 

| Target    | Di                    | visor | Platform Clock    | Actual        | Percent Error |  |
|-----------|-----------------------|-------|-------------------|---------------|---------------|--|
| Baud Rate | Baud Rate Decimal Hex |       | ( CCB ) Frequency | Baud Rate     | (Decimal)     |  |
| (Decimal) |                       |       | (MHz)             | (Decimal)     |               |  |
| 9,600     | 1736                  | 6C8   | 266               | 9600.61444    | 0.0064        |  |
| 19,200    | 868                   | 364   | 266               | 19,201.22888  | 0.0064        |  |
| 38,400    | 434                   | 1B2   | 266               | 38,402.45776  | 0.0064        |  |
| 57,600    | 289                   | 121   | 266               | 57,670.12673  | 0.1217        |  |
| 115,200   | 145                   | 91    | 266               | 114,942.52844 | 0.2235        |  |
| 230,400   | 72                    | 48    | 266               | 231,481.48090 | 0.4694        |  |
| 9,600     | 2170                  | 87A   | 333               | 9600.61444    | 0.0064        |  |
| 19,200    | 1085                  | 43D   | 333               | 19,201.22888  | 0.0064        |  |

**Table 11-7. Baud Rate Examples (continued)** 

| Target    | С       | ivisor | Platform Clock       | Actual        | Percent Error |
|-----------|---------|--------|----------------------|---------------|---------------|
| Baud Rate | Decimal | Hex    | ( CCB )<br>Frequency | Baud Rate     | (Decimal)     |
| (Decimal) |         |        | (MHz)                | (Decimal)     |               |
| 38,400    | 543     | 21F    | 333                  | 38,367.09638  | 0.0858        |
| 57,600    | 362     | 16A    | 333                  | 57,550.64457  | 0.0857        |
| 115,200   | 181     | B5     | 333                  | 115,101.28913 | 0.0857        |
| 230,400   | 90      | 5A     | 333                  | 231,481.48148 | 0.4694        |
| 9,600     | 3472    | D90    | 533                  | 9600.61444    | 0.0064        |
| 19,200    | 1736    | 6C8    | 533                  | 19,201.22888  | 0.0064        |
| 38,400    | 868     | 364    | 533                  | 38,402.45776  | 0.0064        |
| 57,600    | 579     | 243    | 533                  | 57,570.52389  | 0.0512        |
| 115,200   | 289     | 121    | 533                  | 115,340.25375 | 0.1217        |
| 230,400   | 145     | 91     | 533                  | 229,885.05747 | 0.2235        |
| 9,600     | 3906    | F42    | 600                  | 9600.6144     | 0.0064        |
| 19,200    | 1953    | 7A1    | 600                  | 19,201.2288   | 0.0064        |
| 38,400    | 977     | 3D1    | 600                  | 38382.8045    | 0.0448        |
| 57,600    | 651     | 28B    | 600                  | 57603.6866    | 0.0064        |
| 115,200   | 326     | 146    | 600                  | 115030.6748   | 0.1470        |
| 230,400   | 163     | A3     | 600                  | 230061.3497   | 0.1470        |





### DUART\_UDLBn field descriptions

| Field       | Description                                                     |
|-------------|-----------------------------------------------------------------|
| 0–7<br>UDLB | Divisor least significant byte. This is concatenated with UDMB. |

# 11.3.4 Divisor Most Significant Byte Registers (DUART\_UDMBn)

This register is accessible when ULCR[DLAB] = 1.

The divisor least significant byte register (UDLB) is concatenated with the divisor most significant byte register (UDMB) to create the divisor used to divide the input clock into the DUART. The output frequency of the baud generator is 16 times the baud rate; therefore the desired baud rate = platform clock frequency  $\div$  (16 x [UDMB||UDLB]).

Equivalently, [UDMB||UDLB:0b0000] = platform clock frequency  $\div$  desired baud rate. Baud rates that can be generated by specific input clock frequencies are shown in the table in Divisor Least Significant Byte Registers (DUART\_UDLBn).

Address: 4000h base + 501h offset + (256d  $\times$  i), where i=0d to 1d



#### DUART\_UDMBn field descriptions

| Field       | Description                   |
|-------------|-------------------------------|
| 0–7<br>UDMB | Divisor most significant byte |

# 11.3.5 Interrupt Enable Register (DUART\_UIERn)

This register is accessible when ULCR[DLAB] = 0.

The UIER gives the user the ability to mask specific UART interrupts to the programmable interrupt controller (PIC).

Address: 4000h base + 501h offset + (256d  $\times$  i), where i=0d to 1d



#### DUART\_UIERn field descriptions

| Field       | Description                                                                                                      |  |
|-------------|------------------------------------------------------------------------------------------------------------------|--|
| 0–3         | This field is reserved.                                                                                          |  |
| -           | Reserved.                                                                                                        |  |
| 4<br>EMSI   | Enable modem status interrupt.                                                                                   |  |
|             | 0 Mask interrupts caused by UMSR[DCTS] being set                                                                 |  |
|             | 1 Enable and assert interrupts when the clear-to-send bit in the UART modem status register (UMSR) changes state |  |
| 5<br>ERLSI  | Enable receiver line status interrupt.                                                                           |  |
|             | 0 Mask interrupts when ULSR's overrun, parity error, framing error or break interrupt bits are set               |  |
|             | 1 Enable and assert interrupts when ULSR's overrun, parity error, framing error or break interrupt bits are set  |  |
| 6<br>ETHREI | Enable transmitter holding register empty interrupt.                                                             |  |
|             | 0 Mask interrupt when ULSR[THRE] is set                                                                          |  |
|             | 1 Enable and assert interrupts when ULSR[THRE] is set                                                            |  |

### **DUART\_UIER***n* field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                          |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ERDAI | Enable received data available interrupt.                                                                                                                                                                                                                            |
|            | <ul> <li>Mask interrupt when new receive data is available or receive data time out has occurred</li> <li>Enable and assert interrupts when a new data character is received from the external device and/or a time-out interrupt occurs in the FIFO mode</li> </ul> |

# 11.3.6 Interrupt ID Registers (DUART\_UIIRn)

This register is accessible when ULCR[DLAB] = 0.

The UIIRs indicate when an interrupt is pending from the corresponding UART and what type of interrupt is active. They also indicate if the FIFOs are enabled.

The DUART prioritizes interrupts into four levels and records these in the corresponding UIIR. The four levels of interrupt conditions in order of priority are:

- 1. Receiver line status
- 2. Received data ready/character time-out
- 3. Transmitter holding register empty
- 4. Modem status

When the UIIR is read, the associated DUART serial channel freezes all interrupts and indicates the highest priority pending interrupt. While this read transaction is occurring, the associated DUART serial channel records new interrupts, but does not change the contents of UIIR until the read access is complete.

Table 11-15. UIIR IID Bits Summary

| IID Bits IID[3-0] | Priority<br>Level | Interrupt Type          | Interrupt Description                                               | How To Reset<br>Interrupt                                                                                                                                          |
|-------------------|-------------------|-------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0001            | -                 | -                       | -                                                                   | -                                                                                                                                                                  |
| 0b0110            | Highest           | Receiver line status    | Overrun error, parity error, framing error, or break interrupt      | Read the line status register.                                                                                                                                     |
| 0b0100            | Second            | Received data available | Receiver data available<br>or trigger level reached<br>in FIFO mode | Read the receiver<br>buffer register or<br>interrupt is<br>automatically reset if<br>the number of bytes in<br>the receiver FIFO drops<br>below the trigger level. |

Table 11-15. UIIR IID Bits Summary (continued)

| IID Bits IID[3-0] | Priority<br>Level | Interrupt Type     | Interrupt Description                                                                                                                                                           | How To Reset<br>Interrupt           |
|-------------------|-------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| 0b1100            | Second            | Character time-out | No characters have been removed from or input to the receiver FIFO during the last 4 character times and there is at least one character in the receiver FIFO during this time. | Read the receiver buffer register.  |
| 0b0010            | Third             | UTHR empty         | Transmitter holding register is empty                                                                                                                                           | Read the UIIR or write to the UTHR. |
| 0b0000            | Fourth            | Modem status       | CTS_B input value changed since last read of UMSR                                                                                                                               | Read the UMSR.                      |





## DUART\_UIIRn field descriptions

| Field     | Description                                                                                                                                                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1<br>FE | FIFOs enabled. Reflects the setting of UFCR[FEN]                                                                                                                                           |
| 2–3<br>-  | This field is reserved. Reserved                                                                                                                                                           |
| 4<br>IID3 | Interrupt ID bits identify the highest priority interrupt that is pending as indicated in Table 11-15. IID3 is set along with IID2 only when a timeout interrupt is pending for FIFO mode. |
| 5<br>IID2 | Interrupt ID bits identify the highest priority interrupt that is pending as indicated in Table 11-15.                                                                                     |
| 6<br>IID1 | Interrupt ID bits identify the highest priority interrupt that is pending as indicated in Table 11-15.                                                                                     |
| 7<br>IID0 | IID0 indicates when an interrupt is pending.  The UART has an active interrupt ready to be serviced.  No interrupt is pending.                                                             |

# 11.3.7 FIFO Control Registers (DUART\_UFCRn)

This register is accessible when ULCR[DLAB] = 0.

#### **DUART** memory map/register definition

The UFCR, a write-only register, is used to enable and clear the receiver and transmitter FIFOs, set a receiver FIFO trigger level to control the received data available interrupt, and select the type of DMA signaling.

When the UFCR bits are written, the FIFO enable bit must also be set or else the UFCR bits are not programmed. When changing from FIFO mode to 16450 mode (non-FIFO mode) and vice versa, data is automatically cleared from the FIFOs.

After all the bytes in the receiver FIFO are cleared, the receiver internal shift register is not cleared. Similarly, the bytes are cleared in the transmitter FIFO, but the transmitter internal shift register is not cleared. Both TFR and RFR are self-clearing bits.





#### **DUART\_UFCR***n* field descriptions

| Field      | Description                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1<br>RTL | Receiver trigger level. A received data available interrupt occurs when UIER[ERDAI] is set and the number of bytes in the receiver FIFO equals the designated interrupt trigger level as follows: |
|            | 00 1 byte<br>01 4 bytes<br>10 8 bytes                                                                                                                                                             |
|            | 11 14 bytes                                                                                                                                                                                       |
| 2–3<br>-   | This field is reserved. Reserved                                                                                                                                                                  |
| 4<br>DMS   | DMA mode select. See DMA mode select for more information.  0 UDSR[RXRDY] and UDSR[TXRDY] bits are in mode 0.  1 UDSR[RXRDY] and UDSR[TXRDY] bits are in mode 1 if UFCR[FEN] = 1.                 |
| 5<br>TFR   | Transmitter FIFO reset  O No action  Clears all bytes in the transmitter FIFO and resets the FIFO counter/pointer to 0                                                                            |
| 6<br>RFR   | Receiver FIFO reset  0 No action  1 Clears all bytes in the receiver FIFO and resets the FIFO counter/pointer to 0                                                                                |
| 7<br>FEN   | FIFO enable  0 FIFOs are disabled and cleared 1 Enables the transmitter and receiver FIFOs                                                                                                        |

# 11.3.8 Alternate Function Registers (DUART\_UAFRn)

This register is accessible when ULCR[DLAB] = 1.

The UAFRs give software the ability to gate off the baud clock and write to both UART0/UART1 registers simultaneously with the same write operation.

Address: 4000h base + 502h offset + (256d × i), where i=0d to 1d



#### DUART\_UAFRn field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–5<br>- | This field is reserved. Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6<br>BO  | Baud clock select.  O The baud clock is not gated off.  1 The baud clock is gated off.                                                                                                                                                                                                                                                                                                                                                                          |
| 7<br>CW  | Concurrent write enable.  O Disables writing to both UART0 and UART1  Enables concurrent writes to corresponding UART registers. A write to a register in UART0 is also a write to the corresponding register in UART1 and vice versa. The user needs to ensure that the LCR[DLAB] of both UARTs are in the same state before executing a concurrent write to register addresses 0x n 00, 0x n 01 and 0x n 02, where n is the offset of the corresponding UART. |

## 11.3.9 Line Control Registers (DUART ULCRn)

This register is accessible when ULCR[DLAB] = x.

The ULCRs specify the data format for the UART bus and set the divisor latch access bit ULCR[DLAB], which controls the ability to access the divisor latch least and most significant bit registers and the alternate function register.

After initializing the ULCR, the software should not re-write the ULCR when valid transfers on the UART bus are active. The software should not re-write the ULCR until the last STOP bit has been received and there are no new characters being transferred on the bus.

The stick parity bit, ULCR[SP], assigns a set parity value for the parity bit time slot sent on the UART bus. The set value is defined as mark parity (logic 1) or space parity (logic 0). ULCR[PEN] and ULCR[EPS] help determine the set parity value. See Table 11-23

#### **DUART** memory map/register definition

for more information. ULCR[NSTB], defines the number of STOP bits to be sent at the end of the data transfer. The receiver only checks the first STOP bit, regardless of the number of STOP bits selected. The word length select bits (1 and 0) define the number of data bits that are transmitted or received as a serial character. The word length does not include START, parity, and STOP bits.

Table 11-23. Parity Selection Using ULCR[PEN], ULCR[SP], and ULCR[EPS]

| PEN | SP | EPS | Parity Selected |
|-----|----|-----|-----------------|
| 0   | 0  | 0   | No parity       |
| 0   | 0  | 1   | No parity       |
| 0   | 1  | 0   | No parity       |
| 0   | 1  | 1   | No parity       |
| 1   | 0  | 0   | Odd parity      |
| 1   | 0  | 1   | Even parity     |
| 1   | 1  | 0   | Mark parity     |
| 1   | 1  | 1   | Space parity    |

Address: 4000h base + 503h offset + (256d  $\times$  i), where i=0d to 1d

| Bit           | 0    | 1  | 2  | 3   | 4   | 5    | 6 | 7  |
|---------------|------|----|----|-----|-----|------|---|----|
| Read<br>Write | DLAB | SB | SP | EPS | PEN | NSTB | W | LS |
| Reset         | 0    | 0  | 0  | 0   | 0   | 0    | 0 | 0  |

#### DUART\_ULCRn field descriptions

| Field     | Description                                                                                                        |
|-----------|--------------------------------------------------------------------------------------------------------------------|
| 0<br>DLAB | Divisor latch access bit.                                                                                          |
|           | 0 Access to all registers except UDLB, UAFR, and UDMB                                                              |
|           | 1 Ability to access divisor latch least and most significant byte registers and alternate function register (UAFR) |
| 1         | Set break.                                                                                                         |
| SB        | Send normal UTHR data onto the serial output (SOUT) signal                                                         |
|           | 1 Force logic 0 to be on the SOUT signal. Data in the UTHR is not affected                                         |
| 2<br>SP   | Stick parity.                                                                                                      |
|           | 0 Stick parity is disabled.                                                                                        |
|           | 1 If PEN = 1 and EPS = 1, space parity is selected. And if PEN = 1 and EPS = 0, mark parity is selected.           |
| 3<br>EPS  | Even parity select. See Table 11-23 for more information.                                                          |
|           | 0 If PEN = 1 and SP = 0, odd parity is selected.                                                                   |
|           | 1 If PEN = 1 and SP = 0, even parity is selected.                                                                  |
| 4         | Parity enable.                                                                                                     |
| PEN       |                                                                                                                    |

## **DUART\_ULCR***n* field descriptions (continued)

| Field      | Description                                                                                                                                              |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0 No parity generation and checking                                                                                                                      |
|            | 1 Generate parity bit as a transmitter, and check parity as a receiver                                                                                   |
| 5<br>NSTB  | Number of STOP bits.                                                                                                                                     |
| _          | 0 One STOP bit is generated in the transmitted data.                                                                                                     |
|            | 1 When a 5-bit data length is selected, 1½ STOP bits are generated. When either a 6-, 7-, or 8-bit word length is selected, two STOP bits are generated. |
| 6–7<br>WLS | Word length select. Number of bits that comprise the character length. The word length select values are as follows:                                     |
|            | 00 5 bits                                                                                                                                                |
|            | 01 6 bits                                                                                                                                                |
|            | 10 7 bits                                                                                                                                                |
|            | 11 8 bits                                                                                                                                                |

# 11.3.10 Modem Control Registers (DUART\_UMCRn)

This register is accessible when ULCR[DLAB] = x.

The UMCRs control the interface with the external peripheral device on the UART bus.

Address: 4000h base + 504h offset + (256d  $\times$  i), where i=0d to 1d



#### DUART\_UMCRn field descriptions

| Field     | Description                                                                                                                 |
|-----------|-----------------------------------------------------------------------------------------------------------------------------|
| 0–2       | This field is reserved.                                                                                                     |
| -         | Reserved.                                                                                                                   |
| 3<br>LOOP | Local loopback mode.                                                                                                        |
|           | 0 Normal operation                                                                                                          |
|           | 1 Functionally, the data written to UTHR can be read from URBR of the same UART, and UMCR[RTS] is tied to UMSR[CTS].        |
| 4–5<br>-  | This field is reserved. Reserved.                                                                                           |
| 6<br>RTS  | Ready to send.                                                                                                              |
|           | 0 Negates corresponding RTS_B output                                                                                        |
|           | 1 Assert corresponding RTS_B output. Informs external modem or peripheral that the UART is ready for sending/receiving data |
| 7 -       | This field is reserved. Reserved.                                                                                           |

# 11.3.11 Line Status Registers (DUART\_ULSRn)

This register is accessible when ULCR[DLAB] = x.

The ULSRs are read-only registers that monitor the status of the data transfer on the UART buses. To isolate the status bits from the proper character received through the UART bus, software should read the ULSR and then the URBR.





#### DUART\_ULSRn field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RFE  | Receiver FIFO error.                                                                                                                                                                                                                                                                                                                                                                                                |
| RFE       | <ul> <li>This bit is cleared when there are no errors in the receiver FIFO or on a read of the ULSR with no remaining receiver FIFO errors.</li> <li>Set to one when one of the characters in the receiver FIFO encounters an error (framing, parity, or</li> </ul>                                                                                                                                                 |
|           | break interrupt)                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1<br>TEMT | Transmitter empty.                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | O Either or both the UTHR or the internal transmitter shift register has a data character. In FIFO mode, a data character is in the transmitter FIFO or the internal transmitter shift register.                                                                                                                                                                                                                    |
|           | 1 Both the UTHR and the internal transmitter shift register are empty. In FIFO mode, both the transmitter FIFO and the internal transmitter shift register are empty.                                                                                                                                                                                                                                               |
| 2<br>THRE | Transmitter holding register empty.                                                                                                                                                                                                                                                                                                                                                                                 |
|           | 0 The UTHR is not empty.                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 1 A data character has transferred from the UTHR into the internal transmitter shift register. In FIFO mode, the transmitter FIFO contains no data character.                                                                                                                                                                                                                                                       |
| 3<br>Bl   | Break interrupt.                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 0 This bit is cleared when the ULSR is read or when a valid data transfer is detected (that is, STOP bit is received).                                                                                                                                                                                                                                                                                              |
|           | 1 Received data of logic 0 for more than START bit + Data bits + Parity bit + one STOP bits length of time. A new character is not loaded until SIN returns to the mark state (logic 1) and a valid START is detected. In FIFO mode, a zero character is encountered in the FIFO (the zero character is at the top of the FIFO). In FIFO mode, only one zero character is stored.                                   |
| 4<br>FE   | Framing error.                                                                                                                                                                                                                                                                                                                                                                                                      |
|           | 0 This bit is cleared when ULSR is read or when a new character is loaded into the URBR from the<br>receiver shift register.                                                                                                                                                                                                                                                                                        |
|           | 1 Invalid STOP bit for receive data (only the first STOP bit is checked). In FIFO mode, this bit is set when the character that detected a framing error is encountered in the FIFO (that is the character at the top of the FIFO). An attempt to resynchronize occurs after a framing error. The UART assumes that the framing error (due to a logic 0 being read when a logic 1 (STOP) was expected) was due to a |

## **DUART\_ULSR***n* field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | STOP bit overlapping with the next START bit, so it assumes this logic 0 sample is a true START bit and then receives the following new data.                                                                                                                                                                                                                                                |
| 5<br>PE | Parity error.                                                                                                                                                                                                                                                                                                                                                                                |
|         | 0 This bit is cleared when ULSR is read or when a new character is loaded into the URBR.                                                                                                                                                                                                                                                                                                     |
|         | 1 Unexpected parity value encountered when receiving data. In FIFO mode, the character with the error is at the top of the FIFO.                                                                                                                                                                                                                                                             |
| 6       | Overrun error.                                                                                                                                                                                                                                                                                                                                                                               |
| OE      |                                                                                                                                                                                                                                                                                                                                                                                              |
|         | 0 This bit is cleared when ULSR is read.                                                                                                                                                                                                                                                                                                                                                     |
|         | 1 Before the URBR is read, the URBR was overwritten with a new character. The old character is loss. In FIFO mode, the receiver FIFO is full (regardless of the receiver FIFO trigger level setting) and a new character has been received into the internal receiver shift register. The old character was overwritten by the new character. Data in the receiver FIFO was not overwritten. |
| 7<br>DR | Data ready.                                                                                                                                                                                                                                                                                                                                                                                  |
|         | <ul> <li>This bit is cleared when URBR is read or when all of the data in the receiver FIFO is read.</li> <li>A character has been received in the URBR or the receiver FIFO.</li> </ul>                                                                                                                                                                                                     |

# 11.3.12 Modem Status Registers (DUART\_UMSRn)

This register is accessible when ULCR[DLAB] = x.

The UMSRs track the status of the modem (or external peripheral device) clear to send (CTS\_B) signal for the corresponding UART.





## DUART\_UMSRn field descriptions

| Field     | Description                                                                                                                                                                                                                                             |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–2       | This field is reserved. Reserved.                                                                                                                                                                                                                       |
| 3<br>CTS  | Clear to send. Represents the inverted value of the CTS_B input pin from the external peripheral device  Corresponding CTS_B <i>n</i> is negated  Corresponding CTS_B <i>n</i> is asserted. The modem or peripheral device is ready for data transfers. |
| 4–6<br>-  | This field is reserved. Reserved.                                                                                                                                                                                                                       |
| 7<br>DCTS | Clear to send.                                                                                                                                                                                                                                          |

#### **DUART\_UMSR***n* field descriptions (continued)

| Field | Description                                                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
|       | 0 No change on the corresponding CTS_B <i>n</i> signal since the last read of UMSR[CTS]                                                 |
|       | 1 The CTS_B n value has changed, since the last read of UMSR[CTS]. Causes an interrupt if<br>UIER[EMSI] is set to detect this condition |

# 11.3.13 Scratch Registers (DUART\_USCRn)

This register is accessible when ULCR[DLAB] = x.

The USCR registers are for debugging software or the DUART hardware. The USCRs do not affect the operation of the DUART.

Address: 4000h base + 507h offset + (256d  $\times$  i), where i=0d to 1d



#### DUART\_USCRn field descriptions

| Field | Description |
|-------|-------------|
| 0–7   | Data        |
| DATA  |             |

# 11.3.14 DMA Status Registers (DUART\_UDSRn)

This register is accessible when ULCR[DLAB] = x.

The DMA status registers (UDSRs) are read-only registers that return transmitter and receiver FIFO status. UDSRs also provide the ability to assist DMA data operations to and from the FIFOs.

Table 11-35. UDSR[TXRDY] Set Conditions

| DMS | FEN | DMA Mode | Meaning                                                |
|-----|-----|----------|--------------------------------------------------------|
| 0   | 0   | 0        | TXRDY is set after the first                           |
| 0   | 1   | 0        | character is loaded into the transmitter FIFO or UTHR. |
| 1   | 0   | 0        |                                                        |
| 1   | 1   | 1        | TXRDY is set when the transmitter FIFO is full.        |

## Table 11-36. UDSR[TXRDY] Cleared Conditions

| DMS | FEN | DMA Mode | Meaning                                                                                                                                       |
|-----|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 0   | 0        | TXRDY is cleared when there                                                                                                                   |
| 0   | 1   | 0        | are no characters in the transmitter FIFO or UTHR.                                                                                            |
| 1   | 0   | 0        |                                                                                                                                               |
| 1   | 1   | 1        | TXRDY is cleared when there are no characters in the transmitter FIFO or UTHR. TXRDY remains clear when the transmitter FIFO is not yet full. |

# Table 11-37. UDSR[RXRDY] Set Conditions

| DMS | FEN | DMA Mode | Meaning                                                                                  |  |  |
|-----|-----|----------|------------------------------------------------------------------------------------------|--|--|
| 0   | 0   |          | RXRDY is set when there are no characters in the receiver FIFO or URBR.                  |  |  |
| 0   | 1   | I O      |                                                                                          |  |  |
| 1   | 0   | 0        |                                                                                          |  |  |
| 1   | 1   |          | RXRDY is set when the trigger level has not been reached and there has been no time out. |  |  |

## Table 11-38. UDSR[RXRDY] Cleared Conditions

| DMS | FEN | DMA Mode | Meaning                                                                                                                         |  |  |
|-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0   | 0   | 0        | RXRDY is cleared when there                                                                                                     |  |  |
| 0   | 1   | 0        | is at least one character in the receiver FIFO or URBR.                                                                         |  |  |
| 1   | 0   | 0        | Tieceivei Firo di Unan.                                                                                                         |  |  |
| 1   | 1   | 1        | RXRDY is cleared when the trigger level or a time-out has been reached. RXRDY remains cleared until the receiver FIFO is empty. |  |  |

Address: 4000h base + 510h offset + (256d  $\times$  i), where i=0d to 1d



#### DUART\_UDSRn field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                      |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–5<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                 |
| 6<br>TXRDY | Transmitter ready. This read-only bit reflects the status of the transmitter FIFO or the UTHR. The status depends on the DMA mode selected, which is determined by the DMS and FEN bits in the UFCR.  O This bit is cleared, as shown in Table 11-36.  This bit is set, as shown in Table 11-35. |
| 7<br>RXRDY | Receiver ready. This read-only bit reflects the status of the receiver FIFO or URBR. The status depends on the DMA mode selected, which is determined by the DMS and FEN bits in the UFCR.  O This bit is cleared, as shown in Table 11-38.  This bit is set, as shown in Table 11-37.           |

# 11.4 Functional description

The communication channel provides a full-duplex asynchronous receiver and transmitter using an operating frequency derived from the platform clock signal.

The transmitter accepts parallel data with a write access to the transmitter holding register (UTHR). In FIFO mode, the data is placed directly into an internal transmitter shift register, or into the transmitter FIFO-see FIFO mode. The transmitting registers convert the data to a serial bit stream, by inserting the appropriate START, STOP, and optional parity bits. Finally, the registers output a composite serial data stream on the channel transmitter serial data output (SOUT). The transmitter status may be polled or interrupt-driven.

The receiver accepts serial data on the channel receiver serial data input (SIN), converts the data into parallel format, and checks for START, STOP, and parity bits. In FIFO mode, the receiver removes the START, STOP, and parity bits and then transfers the assembled character from the receiver buffer, or receiver FIFO. This transfer occurs in response to a read of the UART receiver buffer register (URBR). The receiver status may be polled or interrupt driven.

## 11.4.1 Serial interface

The UART bus is a serial, full-duplex, point-to-point bus as shown in Figure 11-44. Therefore, only two devices are attached to the same signals and there is no need for address or arbitration bus cycles.



Figure 11-44. UART bus interface transaction protocol example

A standard UART bus transfer is composed of either three or four parts:

- START bit
- Data transfer bits (least-significant bit is first data bit on the bus)
- Parity bit (optional)
- STOP bits

An internal logic sample signal, *rxcnt*, uses the frequency of the baud-rate generator to drive the bits on SOUT.

The following sections describe the four components of the serial interface, the baud-rate generator, local loopback mode, different errors, and FIFO mode.

## 11.4.1.1 START bit

A write to the transmitter holding register (UTHR) generates a START bit on the SOUT signal.

Figure 11-44 shows that the START bit is defined as a logic 0. The START bit denotes the beginning of a new data transfer which is limited to the bit length programmed in the UART line control register (ULCR). When the bus is idle, SOUT is high.

#### 11.4.1.2 Data transfer

Each data transfer contains 5-8 bits of data.

The ULCR data bit length for the transmitter and receiver UART devices must agree before a transfer begins; otherwise, a parity or framing error may occur. A transfer begins when UTHR is written. At that time a START bit is generated followed by 5-8 of the data

#### **Functional description**

bits previously written to the UTHR. The data bits are driven from the least significant to the most significant bits. After the parity and STOP bits, a new data transfer can begin if new data is written to the UTHR.

## 11.4.1.3 Parity bit

The user has the option of using even, odd, no parity, or stick parity.

See Line Control Registers (DUART\_ULCRn). Both the receiver and transmitter parity definition must agree before attempting to transfer data. When receiving data a parity error can occur if an unexpected parity value is detected. See Line Status Registers (DUART\_ULSRn).

#### 11.4.1.4 STOP bit

The transmitter device ends the write transfer by generating a STOP bit.

The STOP bit is always high. The user can program the length of the STOP bit(s) in the ULCR. Both the receiver and transmitter STOP bit length must agree before attempting to transfer data. A framing error can occur if an invalid STOP bit is detected.

## 11.4.2 Baud-rate generator logic

Each UART contains an independent programmable baud-rate generator, that is capable of taking the platform clock input and dividing the input by any divisor from 1 to  $2^{16}$  - 1.

The baud rate is defined as the number of bits per second that can be sent over the UART bus. The formula for calculating baud rate is as follows:

Baud rate = (1/16) x (platform clock frequency  $\div$  divisor value)

Therefore, the output frequency of the baud-rate generator is 16 times the baud rate.

The divisor value is determined by the following two 8-bit registers to form a 16-bit binary number:

- UART divisor most significant byte register (UDMB)
- UART divisor least significant byte register (UDLB)

Upon loading either of the divisor latches, a 16-bit baud-rate counter is loaded.

The divisor latches must be loaded during initialization to ensure proper operation of the baud-rate generator. Both UART devices on the same bus must be programmed for the same baud-rate before starting a transfer.

The baud clock can be passed to the performance monitor by enabling the UAFR[BO] bit. This can be used to determine baud rate errors.

## 11.4.3 Local loopback mode

Local loopback mode is provided for diagnostic testing.

The data written to UTHR can be read from the receiver buffer register (URBR) of the same UART. In this mode, the modem control register UMCR[RTS] is internally tied to the modem status register UMSR[CTS]. The transmitter SOUT is set to a logic 1 and the receiver SIN is disconnected. The output of the transmitter shift register is looped back into the receiver shift register input. The CTS\_B (input signal) is disconnected, RTS\_B is internally connected to CTS\_B, and the RTS\_B (output signal) becomes inactive. In this diagnostic mode, data that is transmitted is immediately received. In local loopback mode the transmit and receive data paths of the DUART can be verified. Note that in local loopback mode, the transmit/receive interrupts are fully operational and can be controlled by the interrupt enable register (UIER).

## **11.4.4 Errors**

The following sections describe framing, parity, and overrun errors which may occur while data is transferred on the UART bus.

Each of the error bits are usually cleared, as described below, when the line status register (ULSR) is read.

## 11.4.4.1 Framing error

When an invalid STOP bit is detected, a framing error occurs and ULSR[FE] is set.

Note that only the first STOP bit is checked. In FIFO mode, ULSR[FE] is set when the character at the top of the FIFO detects a framing error. An attempt to re-synchronize occurs after a framing error. The UART assumes that the framing error (due to a logic 0 being read when a logic 1 (STOP) was expected) was due to a STOP bit overlapping with the next START bit. ULSR[FE] is cleared when ULSR is read or when a new character is loaded into the URBR from the receiver shift register.

## **11.4.4.2** Parity error

A parity error occurs, and ULSR[PE] is set, when unexpected parity values are encountered while receiving data.

In FIFO mode, ULSR[PE] is set when the character with the error is at the top of the FIFO. ULSR[PE] is cleared when ULSR is read or when a new character is loaded into the URBR.

#### 11.4.4.3 Overrun error

When a new (overwriting character) STOP bit is detected and the old character is lost, an overrun error occurs and ULSR[OE] is set.

In FIFO mode, ULSR[OE] is set after the receiver FIFO is full (despite the receiver FIFO trigger level setting) and a new character has been received into the internal receiver shift register. Data in the FIFO is not overwritten; only the shift register data is overwritten. Therefore, the interrupt occurs immediately. ULSR[OE] is cleared when ULSR is read.

## 11.4.5 FIFO mode

The UARTs use an alternate mode (FIFO mode) to relieve the processor core from excessive software overhead.

The FIFO control register (UFCR) is used to enable and clear the receiver and transmitter FIFOs and set the FIFO receiver trigger level UFCR[RTL] to control the received data available interrupt UIER[ERDAI].

The UFCR also selects the type of DMA signaling. The UDSR[RXRDY] indicates the status of the receiver FIFO. The DMA status registers (UDSR[TXRDY]) indicate when the transmitter FIFO is full. When in FIFO mode, data written to UTHR is placed into the transmitter FIFO. The first byte written to UTHR is the first byte onto the UART bus.

# 11.4.5.1 FIFO interrupts

In FIFO mode, the UIER[ERDAI] is set when a time-out interrupt occurs. When a receive data time-out occurs there is a maskable interrupt condition (through UIER[ERDAI]). See Interrupt Enable Register (DUART\_UIERn), for more details on interrupt enables.

The interrupt ID register (UIIR) indicates if the FIFOs are enabled. Interrupt ID3 UIIR[IID3] bit is only set for FIFO mode interrupts. The character time-out interrupt occurs when no characters have been removed from or input to the receiver FIFO during the last four character times and there is at least one character in the receiver FIFO during this time. The character time-out interrupt (controlled by UIIR[IIDn]) is cleared when the URBR is read. See Interrupt ID Registers (DUART\_UIIRn), for more information.

The UIIR[FE] bits indicate if FIFO mode is enabled.

#### 11.4.5.2 DMA mode select

The UDSR[RXRDY] bit reflects the status of the receiver FIFO or URBR.

In mode 0 (UFCR[DMS] is cleared), UDSR[RXRDY] is cleared when there is at least one character in the receiver FIFO or URBR and it is set when there are no more characters in the receiver FIFO or URBR. This occurs regardless of the setting of the UFCR[FEN] bit. In mode 1 (UFCR[DMS] and UFCR[FEN] are set), UDSR[RXRDY] is cleared when the trigger level or a time-out has been reached and it is set when there are no more characters in the receiver FIFO.

The UDSR[TXRDY] bit reflects the status of the transmitter FIFO or UTHR. In mode 0 (UFCR[DMS] is cleared), UDSR[TXRDY] is cleared when there are no characters in the transmitter FIFO or UTHR and it is set after the first character is loaded into the transmitter FIFO or UTHR. This occurs regardless of the setting of the UFCR[FEN] bit. In mode 1 (UFCR[DMS] and UFCR[FEN] are set), UDSR[TXRDY] is cleared when there are no characters in the transmitter FIFO or UTHR and it is set when the transmitter FIFO is full.

See DMA Status Registers (DUART\_UDSRn), for a complete description of the USDR[RXRDY] and USDR[TXRDY] bits.

## 11.4.5.3 Interrupt control logic

An interrupt is active when DUART interrupt ID register bit 7 (UIIR[IID0]), is cleared.

The interrupt enable register (UIER) is used to mask specific interrupt types. For more details refer to the description of UIER in Interrupt Enable Register (DUART\_UIERn).

When the interrupts are disabled in UIER, polling software cannot use UIIR[IID0] to determine whether the UART is ready for service. The software must monitor the appropriate bits in the line status (ULSR) and/or the modem status (UMSR) registers. UIIR[IID0] can be used for polling if the interrupts are enabled in UIER.

# 11.5 DUART initialization/application information

The following requirements must be met for DUART accesses:

- All DUART registers must be mapped to a cache-inhibited and guarded area. (That is, the WIMG setting in the MMU needs to be 0b01X1.)
- All DUART registers are 1 byte wide. Reads and writes to these registers must be byte-wide operations.

A system reset puts the DUART registers to a default state. Before the interface can transfer serial data, the following initialization steps are recommended:

- 1. Update the programmable interrupt controller (PIC) DUART channel interrupt vector source registers.
- 2. Set data attributes and control bits in the ULCR, UFCR, UAFR, UMCR, UDLB, and UDMB.
- 3. Set the data attributes and control bits of the external modem or peripheral device.
- 4. Set the interrupt enable register (UIER).
- 5. To start a write transfer, write to the UTHR.
- 6. Poll UIIR if the interrupts generated by the DUART are masked.

# Chapter 12 Enhanced local bus controller (eLBC)

This chapter describes the external signals and the memory-mapped registers as well as a functional description of the general-purpose chip-select machine (GPCM), NAND Flash control machine (FCM), and user-programmable machines (UPMs) of the eLBC. Finally, it includes an initialization and applications information section with many specific examples of its use.

## 12.1 eLBC introduction

This chapter describes the enhanced local bus controller (eLBC) block.

It describes the external signals and the memory-mapped registers as well as a functional description of the general-purpose chip-select machine (GPCM), NAND Flash control machine (FCM), and user-programmable machines (UPMs) of the eLBC. Finally, it includes an initialization and applications information section with many specific examples of its use.

The figure below is a functional block diagram of the eLBC, which supports three interfaces: GPCM, FCM, and UPM controllers.



Figure 12-1. Enhanced local bus controller block diagram

## 12.1.1 Overview

The main component of the eLBC is its memory controller, which provides a seamless 16-bit interface to many types of memory devices and peripherals.

The memory controller is responsible for controlling eight memory banks shared by a GPCM, an FCM, and up to three UPMs. As such, it supports a minimal glue logic interface to SRAM, EPROM, NOR Flash EEPROM, NAND Flash EEPROM, burstable RAM, regular DRAM devices, extended data output DRAM devices, and other peripherals. The external address latch signal (LALE) allows multiplexing of addresses with data signals to reduce the device pin count.

The eLBC also includes a number of data checking and protection features such as data parity generation and checking, write protection, and a bus monitor to ensure that each bus cycle is terminated within a user-specified period.

#### **12.1.2 Features**

The eLBC main features are as follows:

- Memory controller with eight memory banks
  - 32-bit address decoding with mask
  - Variable memory block sizes (32 Kbytes to 4 Gbytes)
  - Selection of control signal generation on a per-bank basis
  - Data buffer controls activated on a per-bank basis
  - Automatic segmentation of large transactions into memory accesses optimized for bus width and addressing capability
  - Odd/even parity checking for single access
  - Write-protection capability
  - Parity byte-select
- General-purpose chip-select machine (GPCM)
  - Compatible with SRAM, EPROM, NOR Flash EEPROM, and peripherals
  - Global (boot) chip-select available at system reset
  - Boot chip-select support for 8- and 16-bit devices
  - Minimum three-clock access to external devices
  - Two byte-write-enable signals (LWE\_B[0:1])
  - Output enable signal (LOE\_B)
  - External access termination signal (LGTA\_B)
- NAND Flash control machine (FCM)
  - Compatible with small (512 + 16 bytes) and large (2048 + 64 bytes) page parallel NAND Flash EEPROM
  - Global (boot) chip-select available at system reset, with 4-Kbyte boot block buffer for execute-in-place boot loading
  - ECC checking enable/disable feature supported during boot
  - Read-only ECC registers to verify after write operation
  - Boot chip-select support for 8-bit devices
  - Dual 2-Kbyte/eight 512-byte buffers allow simultaneous data transfer during Flash reads and programming
  - Interrupt-driven block transfer for reads and writes
  - Programmable command and data transfer sequences of up to eight steps supported
  - Generic command and address registers support proprietary Flash interfaces
  - Block write locking to ensure system security and integrity

#### **eLBC** introduction

- Three user-programmable machines (UPMs)
  - Programmable-array-based machine controls external signal timing with a granularity of up to one quarter of an external bus clock period
  - User-specified control-signal patterns run when an internal master requests a single-beat or burst read or write access.
  - UPM refresh timer runs a user-specified control signal pattern to support refresh
  - User-specified control-signal patterns can be initiated by software
  - Each UPM can be defined to support DRAM devices with depths of 64, 128, 256, and 512 Kbytes, and 1, 2, 4, 8, 16, 32, 64, 128, and 256 Mbytes
  - Support for 8- and 16-bit devices
  - Page mode support for successive transfers within a burst
  - Internal address multiplexing supporting 64-, 128-, 256-, and 512-Kbyte, and 1-, 2-, 4-, 8-, 16-, 32-, 64-, 128-, and 256-Mbyte page banks
- Optional monitoring of transfers between local bus internal masters and local bus slaves (local bus error reporting on interrupt and status registers)
- Different machines (FCM/GPCM/UPM) share the address, data, and control signals. While the eLBC is servicing a transaction, subsequent transactions are queued until the current transaction has completed.

# 12.1.3 Modes of operation

The eLBC provides one GPCM, one FCM, and three UPMs for the local bus, with no restriction on how many of the eight banks (chip selects) can be programmed to operate with any given machine.

The internal transaction address is limited to 32 bits, so all chip selects must fall within the 4-Gbyte window addressed by the internal transaction address. When a memory transaction is dispatched to the eLBC, the internal transaction address is compared with the address information of each bank (chip select). The corresponding machine assigned to that bank (GPCM, FCM, or UPM) then takes ownership of the external signals that control the access and maintains control until the transaction ends. Thus, with the eLBC in GPCM or FCM, or UPM mode, only one of the eight chip selects is active at any time for the duration of the transaction except in the case of UPM refresh where all UPM machines that are enabled for refresh have concurrent chip select assertion.

## 12.1.3.1 eLBC bus clock and clock ratios

The eLBC supports ratios of 4, 8, and 16 between the faster internal (platform) clock and slower external bus clock (LCLK[0:1]).

This ratio is software programmable through the clock ratio register (LCRR[CLKDIV]).

This ratio affects the resolution of signal timing shifts in GPCM and FCM modes and the interpretation of UPM array words in UPM mode. The bus clock is driven identically onto pins, LCLK[0:1], to allow the clock load to be shared equally across a set of signal nets, thereby enhancing the edge rates of the bus clock.

## 12.1.3.2 Source ID debug mode

The eLBC provides the ID of a transaction source on external device pins. When those pins are selected, the 5-bit internal ID of the current transaction source appears on MSRCID[0:4] whenever valid address or data is available on the eLBC external pins. The reserved value of 0x1F, which indicates invalid address or data, appears on the source ID pins at all other times. The combination of a valid source ID (any value except 0x1F) and the value of external address latch enable (LALE) and data valid (MDVAL) facilitate capturing useful debug data as follows:

- If a valid source ID is detected on MSRCID[0:4] and LALE is asserted, a valid full 32-bit address may be latched from LAD[0:15] and combined with LA[16:31].
- If a valid source ID is detected on MSRCID[0:4] and MDVAL is asserted, valid data may be latched from LAD.

The MSRCID[0:4] and MDVAL signals are multiplexed with other functions sharing the same external pins. See Signal Descriptions, and Reset Clocking, and Initialization, and, and to learn how to enable the MSRCID/MDVAL pins.

# 12.2 eLBC external signal descriptions

Table 12-1 contains a list of external signals related to the eLBC and summarizes their function.

Name **Alternate** Mode **Descriptions** No. of I/O **Signals** Function(s) LALE 0 External address latch enable LCS\_B[0] 0 Chip select 0 1 7 LCS[\_B1:7] 0 Chip selects [1-7] O 1 LWE0\_B/ LWE\_B **GPCM** Write enable 0 LFWE\_B **FCM** LFWE\_B Write enable LBS\_B **UPM** Byte (lane) select 0 LBS\_B0

Table 12-1. Signal properties-summary

Table 12-1. Signal properties-summary (continued)

| Name           | Alternate<br>Function(s) | Mode | Descriptions                             | No. of<br>Signals | I/O |
|----------------|--------------------------|------|------------------------------------------|-------------------|-----|
| LWE1_B /LBS1_B | LWE_B                    | GPCM | Write enable 1                           | 1                 | 0   |
|                | LBS_B                    | UPM  | Byte (lane) select 1                     | 1                 |     |
| LGPL0/ LFCLE   | LGPL0                    | UPM  | General purpose line 0                   | 1                 | 0   |
|                | LFCLE                    | FCM  | Flash command latch enable               | 1                 |     |
| LGPL1/ LFALE   | LGPL1                    | UPM  | General purpose line 1                   | 1                 | 0   |
|                | LFALE                    | FCM  | Flash address latch enable               | 1                 | -   |
| LOE_B/ LGPL2/  | LOE_B                    | GPCM | Output enable                            | 1                 | 0   |
| LFRE_B         | LFRE_B                   | FCM  | Flash read enable                        | 1                 |     |
|                | LGPL2                    | UPM  | General purpose line 2                   | 1                 |     |
| LGPL3/ LFWP_B  | LGPL3                    | UPM  | General purpose line 3                   | 1                 | 0   |
|                | LFWP_B                   | FCM  | Flash write protect                      | 1                 |     |
| LGPL4/         | LGPL4                    | UPM  | General purpose line 4                   | 1                 | 0   |
| LFRB_B/LGTA_B/ | LFRB_B                   | FCM  | Flash ready/busy , open-drain shared pin | 1                 | I   |
| LUPWAIT/ LPBSE | LGTA_B                   | GPCM | Transaction termination                  | 1                 | I   |
|                | LUPWAIT                  | UPM  | External device wait                     | 1                 | I   |
|                | LPBSE                    | -    | Local bus parity byte select             | 1                 | 0   |
| LGPL5          | -                        | UPM  | General purpose line 5                   | 1                 | 0   |
| LBCTL          | -                        | -    | Data buffer control                      | 1                 | 0   |
| LA[16:31]      | -                        | -    | Non-multiplexed address bus              | 16                | 0   |
| LAD[0:15]      | -                        | -    | Multiplexed address/data bus             | 16                | I/O |
| LDP[0:1]       | -                        | -    | Local bus data parity                    | 2                 | I/O |
| LCLK[0:1]      | -                        | -    | Local bus clocks                         | 2                 | 0   |

Table 12-2. Enhanced local bus controller detailed signal descriptions

| Signal     | I/O |                  | Description                                                                                                                                                                                                                                                                               |  |  |
|------------|-----|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| LALE       | 0   |                  | External address latch enable. The local bus memory controller provides control for an external address latch, which allows address and data to be multiplexed on the device pins.                                                                                                        |  |  |
|            |     | State<br>Meaning | Asserted/Negated-LALE is asserted with the address at the beginning of each memory controller transaction. The number of cycles for which it is asserted is governed by the ORn[EAD] and LCRR[EADC] fields. Note that no other control signals are asserted during the assertion of LALE. |  |  |
| LCS_B[0:7] | 0   | Chip sele        | Chip selects. Eight chip selects are provided that are mutually exclusive.                                                                                                                                                                                                                |  |  |
|            |     | State<br>Meaning | Asserted/Negated-Used to enable specific memory devices or peripherals connected to the eLBC. LCS_B[0:7] are provided on a per-bank basis with LCS0_B corresponding to the chip select for memory bank 0, which has the memory type and attributes defined by BR0 and OR0.                |  |  |

Table 12-2. Enhanced local bus controller detailed signal descriptions (continued)

| Signal                                | I/O |                                                                                                                                                                                                                                                                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|---------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| LWE0_B/<br>LFWE_B/<br>LBS0_B,         | 0   | GPCM write enable 0/FCM write enable/UPM byte select 0. These signals select or validate each by lane of the data bus. For an 8-bit port size, bit 0 is the only defined signal. The least-significant addrebits of each access also determine which byte lanes are considered valid for a given data transfer. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LWE1 _B/<br>LBS1 _B                   |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-For GPCM operation, LWE_B[ 0:1] assert for each byte lane enabled for writing. LFWE_B enables command, address, and data writes to NAND Flash EEPROMs controlled by FCM. LBS_B[ 0:1] are programmable byte-select signals in UPM mode. See RAM array, for programming details about LBS_B[ 0:1].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                                       |     | Timing                                                                                                                                                                                                                                                                                                          | Assertion/Negation-See General-purpose chip-select machine (GPCM), for details regarding the timing of LWE_B[ 0:1].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| LGPL0/                                | 0   | General purpose line 0/FCM command latch enable.                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LFCLE                                 |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-In UPM mode, LGPL0 is one of six general purpose signals; it is driven with a value programmed into the UPM array. In FCM mode, LFCLE enables command cycles to NAND Flash EEPROMs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| LGPL1/                                | 0   | General-p                                                                                                                                                                                                                                                                                                       | burpose line 1/FCM address latch enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| LFALE                                 |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-In UPM mode, LGPL1 is one of six general purpose signals; it is driven with a value programmed into the UPM array. In FCM mode, LFALE enables address cycles to NAND Flash EPROMs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| LOE_B/                                | 0   | GPCM ou                                                                                                                                                                                                                                                                                                         | tput enable/General-purpose line 2/FCM read enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| LGPL2/<br>LFRE_B                      |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-Controls the output buffer of memory when accessing memory/devices in GPCM mode. In UPM mode, LGPL2 is one of six general purpose signals; it is driven with a value programmed into the UPM array. LFRE_B enables data read cycles from NAND Flash EEPROMs controlled by FCM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LGPL3/                                | 0   | General-p                                                                                                                                                                                                                                                                                                       | purpose line 3/FCM write protect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| LFWP_B                                |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-In UPM mode, LGPL3 is one of six general purpose signals; it is driven with a value programmed into the UPM array. In FCM mode LFWP_B protects NAND Flash EEPROMs from accidental erasure and programming when LFWP_B is asserted low-see Flash mode register (eLBC_FMR), for programming of FCM operations to control LFWP_B.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LGTA_B/                               | I/O | GPCM tra                                                                                                                                                                                                                                                                                                        | ansfer acknowledge/General-purpose line 4/FCM Flash ready-busy/UPM wait/parity byte select.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| LGPL4/<br>LFRB_B<br>LUPWAIT/<br>LPBSE |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-Input in GPCM or FCM modes used for transaction termination. It may also be configured as one of six general-purpose output signals when in UPM mode or as an input to force the UPM controller to wait for the memory/device. FCM uses LFRB_B to stall during long-latency read and programming operations, continuing once LFRB_B returns high. When configured as LPBSE, it disables any use in GPCM, FCM, or UPM modes. Because systems that use read-modify-write parity require an additional memory device, they must generate a byte-select like a normal data device. ANDing LBSn_B through external logic to achieve the logical function of this byte-select can affect memory access timing. The LBC provides this optional byte-select signal connection to RMW-parity devices. |  |  |
| LGPL5                                 | 0   | General-p                                                                                                                                                                                                                                                                                                       | ourpose line 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                       |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-One of six general purpose signals when in UPM mode, and drives a value programmed in the UPM array.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| LBCTL                                 | 0   |                                                                                                                                                                                                                                                                                                                 | er control. The memory controller activates LBCTL for the local bus when a GPCM-, UPM-, or trolled bank is accessed. Buffer control is disabled by setting ORn[BCTLD].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                                       |     | State<br>Meaning                                                                                                                                                                                                                                                                                                | Asserted/Negated-The LBCTL pin normally functions as a write/read_B control for a bus transceiver connected to the LAD lines. Note that an external data buffer must not drive the LAD lines in conflict with the eLBC when LBCTL is high, because LBCTL remains high after reset and during address phases.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

**Enhanced Local Bus Controller (eLBC) Memory Map** 

Table 12-2. Enhanced local bus controller detailed signal descriptions (continued)

| Signal    | I/O                     |                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LA[16:31] | 0                       | Nonmultip<br>a don't ca | olexed address bus. All bits driven are defined for 8-bit port sizes. For 16-bit port sizes LA[31] is re.                                                                                                                                                                                                                                                                                                                                                                                            |
|           |                         | State<br>Meaning        | Asserted/Negated-LA is the address bus used to transmit addresses to external RAM devices. Refer to eLBC initialization/application information, for address signal multiplexing.                                                                                                                                                                                                                                                                                                                    |
| LAD[0:15] | lane (at address offset |                         | ed address/data bus. For a port size of 16 bits, LAD[0:7] connect to the most-significant byte ddress offset 0), while LAD[8:15] connect to the least-significant byte lane (at address offset 1). size of 8 bits, only LAD[0:7] are connected to the external RAM.                                                                                                                                                                                                                                  |
|           |                         | State<br>Meaning        | Asserted/Negated-LAD is the shared 16-bit address/data bus through which external RAM devices transfer data and receive addresses.                                                                                                                                                                                                                                                                                                                                                                   |
|           |                         | Timing                  | Assertion/Negation-During assertion of LALE, LAD are driven with the RAM address for the access to follow. External logic should propagate the address on LAD while LALE is asserted, and latch the address upon negation of LALE. After LALE is negated, LAD are either driven by write data or are made high-impedance by the eLBC in order to sample read data driven by an external device. Following the last data transfer of a write access, LAD are again taken into a high-impedance state. |
| LDP[0: 1] | I/O                     |                         | data parity. Drives and receives the data parity corresponding with the data phases on LAD for d UPM controlled banks.                                                                                                                                                                                                                                                                                                                                                                               |
|           |                         | State<br>Meaning        | Asserted/Negated-During write accesses, a parity bit is generated for each 8 bits of LAD[ 0:15], such that LDP0 is even/odd parity for LAD[0:7], while LDP[ 1] is even/odd parity for LAD[ 8:15]. Unused byte lanes for port sizes less than 16 bits have undefined parity.                                                                                                                                                                                                                          |
|           |                         | Timing                  | Assertion/Negation-Drive and receive the data parity corresponding with the data phases on LAD. For read accesses, the parity bits for each byte lane are sampled on LDP[0: 1] with the same timing that read data is sampled on LAD. LDP[0:1] change impedance in concert with LAD.                                                                                                                                                                                                                 |
| LCLK[0:1] | 0                       | Local bus clocks        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           |                         | State<br>Meaning        | Asserted/Negated-LCLK[ 0:1 ] drive an identical bus clock signal for distributed loads.                                                                                                                                                                                                                                                                                                                                                                                                              |

# 12.3 Enhanced Local Bus Controller (eLBC) Memory Map

The table below shows the memory mapped registers of the eLBC. Undefined 4-byte address spaces within offset 0x0000-0xFFFF are reserved and should not be accessed for reading or writing. Similarly, only zero should be written to reserved bits of defined registers, as writing ones can have unpredictable results in some cases.

Bits designated as write-one-to-clear are cleared only by writing ones to them. Writing zeros to them has no effect.

### **eLBC** memory map

| Offset<br>address<br>(hex)                         | dress Register name                                                 |    | Access     | Reset value     | Section/<br>page |  |
|----------------------------------------------------|---------------------------------------------------------------------|----|------------|-----------------|------------------|--|
| 5000                                               | Base register 0 (eLBC_BR0)                                          | 32 | R/W        | See section     | 12.3.1/544       |  |
| 5004                                               | Options register 0 layout for GPCM Mode (eLBC_ORg0)                 | 32 | R/W        | 0000_0FF7h      | 12.3.2/546       |  |
| 5004                                               | Options register 0 layout for FCM Mode (eLBC_ORf0)                  | 32 | R/W        | See section     | 12.3.3/549       |  |
| 5004                                               | Options register 0 layout for UPM Mode (eLBC_ORu0)                  | 32 | R/W        | See section     | 12.3.4/553       |  |
| 5008                                               | Base register n (eLBC_BR1)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 500C                                               | Options register n layout for GPCM Mode (eLBC_ORg1)                 | 32 | R/W        | 0000_0000h      | 12.3.6/558       |  |
| 500C                                               | Options register n layout for FCM Mode (eLBC_ORf1)                  | 32 | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 500C                                               | Options register n layout for UPM Mode (eLBC_ORu1)                  | 32 | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5010                                               | Base register n (eLBC_BR2)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 5014                                               | Options register n layout for GPCM Mode (eLBC_ORg2)                 | 32 | R/W        | 0000_0000h      | 12.3.6/558       |  |
| 5014                                               | Options register n layout for FCM Mode (eLBC_ORf2)                  | 32 | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 5014                                               | Options register n layout for UPM Mode (eLBC_ORu2)                  | 32 | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5018                                               | Base register n (eLBC_BR3)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 501C                                               | Options register n layout for GPCM Mode (eLBC_ORg3)                 | 32 | R/W        | 0000_0000h      | 12.3.6/558       |  |
| 501C                                               | Options register n layout for FCM Mode (eLBC_ORf3)                  | 32 | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 501C                                               | Options register n layout for UPM Mode (eLBC_ORu3)                  | 32 | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5020                                               | Base register n (eLBC_BR4)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 5024                                               | Options register n layout for GPCM Mode (eLBC_ORg4)                 | 32 | R/W        | 0000_0000h      | 12.3.6/558       |  |
| 5024                                               | Options register n layout for FCM Mode (eLBC_ORf4)                  |    | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 5024                                               | Options register n layout for UPM Mode (eLBC_ORu4)                  |    | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5028                                               | Base register n (eLBC_BR5)                                          |    | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 502C                                               | Options register n layout for GPCM Mode (eLBC_ORg5) 32 R/W 0000_000 |    | 0000_0000h | 12.3.6/558      |                  |  |
| 502C                                               | Options register n layout for FCM Mode (eLBC_ORf5)                  |    | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 502C                                               | Options register n layout for UPM Mode (eLBC_ORu5)                  | 32 | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5030                                               | Base register n (eLBC_BR6)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 5034                                               | Options register n layout for GPCM Mode (eLBC_ORg6)                 | 32 | R/W        | 0000_0000h      | 12.3.6/558       |  |
| 5034                                               | Options register n layout for FCM Mode (eLBC_ORf6)                  | 32 | R/W        | 0000_0000h      | 12.3.7/562       |  |
| 5034                                               | Options register n layout for UPM Mode (eLBC_ORu6)                  | 32 | R/W        | 0000_0000h      | 12.3.8/566       |  |
| 5038                                               | Base register n (eLBC_BR7)                                          | 32 | R/W        | 0000_0000h      | 12.3.5/557       |  |
| 503C                                               |                                                                     |    | 0000_0000h | 12.3.6/558      |                  |  |
| 503C                                               | Options register n layout for FCM Mode (eLBC_ORf7) 32 R/W 0000_0000 |    | 0000_0000h | 12.3.7/562      |                  |  |
| 503C                                               | Options register n layout for UPM Mode (eLBC_ORu7) 32 R/W 000       |    | 0000_0000h | 12.3.8/566      |                  |  |
| 5068                                               | UPM address register (eLBC_MAR) 32 R/W 0000_0000h                   |    | 12.3.9/568 |                 |                  |  |
| 5070                                               | UPMn mode register (eLBC_MAMR) 32 R/W 0000_000                      |    | 0000_0000h | 12.3.10/<br>569 |                  |  |
| 5074                                               | UPMn mode register (eLBC_MBMR) 32 R/W 0000_0000h                    |    |            |                 | 12.3.10/<br>569  |  |
| 5078 UPMn mode register (eLBC_MCMR) 32 R/W 0000_00 |                                                                     |    |            | 0000_0000h      | 12.3.10/<br>569  |  |

## **eLBC** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                                                 | Width<br>(in bits) | Access     | Reset value     | Section/<br>page |
|----------------------------|-----------------------------------------------------------------------------------------------|--------------------|------------|-----------------|------------------|
| 5084                       | Memory refresh timer prescaler register (eLBC_MRTPR)                                          | 32                 | R/W        | 0000_0000h      | 12.3.11/<br>572  |
| 5088                       | UPM data register (eLBC_MDRu)                                                                 | 32                 | R/W        | 0000_0000h      | 12.3.12/<br>572  |
| 5088                       | FCM data register (eLBC_MDRf)                                                                 | 32                 | R/W        | 0000_0000h      | 12.3.13/<br>573  |
| 5090                       | Special operation initiation register (eLBC_LSOR)                                             | 32                 | R/W        | 0000_0000h      | 12.3.14/<br>573  |
| 50A0                       | UPM refresh timer (eLBC_LURT)                                                                 | 32                 | R/W        | 0000_0000h      | 12.3.15/<br>574  |
| 50B0                       | Transfer error status register (eLBC_LTESR)                                                   | 32                 | w1c        | 0000_0000h      | 12.3.16/<br>575  |
| 50B4                       | Transfer error disable register (eLBC_LTEDR)                                                  | 32                 | R/W        | 0000_0000h      | 12.3.17/<br>577  |
| 50B8                       | Transfer error interrupt register (eLBC_LTEIR)                                                | 32                 | R/W        | 0000_0000h      | 12.3.18/<br>578  |
| 50BC                       | Transfer error attributes register (eLBC_LTEATR) 32 R/W 0000_0000h                            |                    | 0000_0000h | 12.3.19/<br>579 |                  |
| 50C0                       | Transfer error address register (eLBC_LTEAR) 32 R/W 0000_0000h                                |                    | 0000_0000h | 12.3.20/<br>580 |                  |
| 50C4                       | Transfer error ECC register (eLBC_LTECCR) 32 w1c 0000_0000h                                   |                    | 0000_0000h | 12.3.21/<br>581 |                  |
| 50D0                       | Configuration register (eLBC_LBCR)                                                            | 32 R/W 0000_0000h  |            | 12.3.22/<br>582 |                  |
| 50D4                       | Clock ratio register (eLBC_LCRR)                                                              | 32                 | R/W        | R/W See section |                  |
| 50E0                       | Flash mode register (eLBC_FMR)                                                                | 32                 | R/W        | See section     | 12.3.24/<br>585  |
| 50E4                       | Flash instruction register (eLBC_FIR)                                                         | 32                 | R/W        | 0000_0000h      | 12.3.25/<br>587  |
| 50E8                       | Flash command register (eLBC_FCR)                                                             | 32                 | R/W        | 0000_0000h      | 12.3.26/<br>589  |
| 50EC                       | Flash block address register (eLBC_FBAR)                                                      | 32                 | R/W        | 0000_0000h      | 12.3.27/<br>589  |
| 50F0                       | Flash page address register [Large Page Device (ORx[PGS] 32 R/W 0000_0000r = 1)] (eLBC_FPARI) |                    | 0000_0000h | 12.3.28/<br>590 |                  |
| 50F0                       | Flash page address register [Small Page Device (ORx[PGS] 32 B/                                |                    | R/W        | 0000_0000h      | 12.3.29/<br>591  |
| 50F4                       | Flash byte count register (eLBC_FBCR) 32 R/W 0000_0000                                        |                    | 0000_0000h | 12.3.30/<br>592 |                  |
| 5100                       | Flash ECC block n registers (eLBC_FECC0) 32 R 0000_0000                                       |                    | 0000_0000h | 12.3.31/<br>593 |                  |
| 5104                       | Flash ECC block n registers (eLBC_FECC1)                                                      | 32                 | R          | 0000_0000h      | 12.3.31/<br>593  |

#### Chapter 12 Enhanced local bus controller (eLBC)

## eLBC memory map (continued)

| Offset address (hex) | Register name                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------|--------------------|--------|-------------|------------------|
| 5108                 | Flash ECC block n registers (eLBC_FECC2) | 32                 | R      | 0000_0000h  | 12.3.31/<br>593  |
| 510C                 | Flash ECC block n registers (eLBC_FECC3) | 32                 | R      | 0000_0000h  | 12.3.31/<br>593  |

### 12.3.1 Base register 0 (eLBC\_BR0)

The base registers (BR n) contain the base address and address types for each memory bank. The memory controller uses this information to compare the address bus value with the current address accessed. Each register (bank) includes a memory attribute and selects the machine for memory operation handling. Note that after system reset, BR0[V] is set, BR1[V]-BR7[V] are cleared, and the value of BR0[PS] reflects the initial port size configured by the boot ROM location power-on configuration settings .



- \* Notes:
- V field: BR0 has its valid bit (V) set at reset. Thus bank 0 is valid with the port size (PS) configured from cfg\_rom\_loc[0:3] at power-on reset.
- MSEL field: M = 0 for MSEL of GPCM, 1 for MSEL of FCM at boot.
- DECC field: The reset value for DECC is determined by cfg\_elbc\_ecc .
- PS field: Thus bank 0 is valid with the port size (PS) configured from cfg\_rom\_loc[0:3] at power-on reset .

#### eLBC\_BR0 field descriptions

| Field | Description                                                                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BA    | Base address. The upper 17 bits of each base register are compared to the address on the address bus to determine if the bus master is accessing a memory bank controlled by the memory controller. Used with the address mask bits $OR n$ [AM]. |

## eLBC\_BR0 field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17–18         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19–20<br>PS   | Port size. Specifies the port size of this memory region. For BR0, PS is configured from the boot ROM location power-on reset configuration setting . For all other banks the value is reset to 00 (port size not defined).  OR Reserved  Besit (supported for GPCM, UPM, FCM)  Reserved  Reserved                                                                                                                                              |
| 21–22<br>DECC | <ul> <li>Specifies the method for data error checking.</li> <li>Data error checking disabled, but normal parity generation for GPCM and UPM. No ECC generation for FCM.</li> <li>ECC checking is enabled, but ECC generation is disabled, for FCM on full-page transfers. Normal parity generation and checking for GPCM and UPM.</li> <li>ECC checking and generation are enabled for FCM on full-page transfers.</li> <li>Reserved</li> </ul> |
| 23<br>WP      | <ul> <li>Write protect.</li> <li>Read and write accesses are allowed.</li> <li>Only read accesses are allowed. The memory controller does not assert LCSn on write cycles to this memory bank. LTESR[WP] is set (if WP is set) if a write to this memory bank is attempted, and a local bus error interrupt is generated (if enabled), terminating the cycle.</li> </ul>                                                                        |
| 24–26<br>MSEL | Machine select. Specifies the machine to use for handling memory operations.  000 GPCM (possible reset value)  001 FCM (possible reset value)  010 Reserved  011 Reserved  100 UPMA  101 UPMB  110 UPMC  111 Reserved                                                                                                                                                                                                                           |
| 27            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28–29<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31<br>V       | Valid bit. Indicates that the contents of the BR <i>n</i> and OR <i>n</i> pair are valid.    CSn does not assert unless V is set (an access to a region that has no valid bit set may cause a bus time-out). After a system reset, only BR0[V] is set.  This bank is invalid.  This bank is valid.                                                                                                                                              |

### 12.3.2 Options register 0 layout for GPCM Mode (eLBC\_ORg0)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

- GPCM mode
- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the GPCM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

| Boot Source                    | OR0 Reset Value |
|--------------------------------|-----------------|
| FCM (small page NAND Flash)    | 0000_03AE       |
| FCM (large page NAND Flash)    | 0000_07AE       |
| GPCM                           | 0000_0FF7       |
| eLBC not used as a boot source | 0000_0F07       |

Table 12-5. Reset value of OR0 Register

The address mask field of the option registers (OR n [AM]) masks up to 17 corresponding BR n [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-6. Memory Bank Sizes in Relation to Address Mask

| AM                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0000_0 | 512 Mbytes       |
| 1111_0000_0000_0000_0 | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |

Table 12-6. Memory Bank Sizes in Relation to Address Mask (continued)

| AM                    | Memory Bank Size |
|-----------------------|------------------|
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_10000_0     | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_11100_0     | 256 Kbytes       |
| 1111_1111_1110_0      | 128 Kbytes       |
| 1111_1111_1111_0      | 64 Kbytes        |
| 1111_1111_1111_1      | 32 Kbytes        |





eLBC\_ORg0 field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>AM  | GPCM address mask. Masks corresponding BRn bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map.  O Corresponding address bits are masked and therefore don't care for address checking.  Corresponding address bits are used in the comparison between base and transaction addresses. |
| 17–18<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 19<br>BCTLD | Buffer control disable. Disables assertion of LBCTL during access to the current memory bank.  0 LBCTL is asserted upon access to the current memory bank.  1 LBCTL is not asserted upon access to the current memory bank.                                                                                                                                                                                                                                                                |

## eLBC\_ORg0 field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20<br>CSNT   | Chip select negation time. Determines when $\overline{LCSn}$ and $\overline{LWE}$ are negated during an external memory write access handled by the GPCM, provided that ACS $\neq$ 00 (when ACS = 00, only $\overline{LWE}$ is affected by the setting of CSNT). This helps meet address/data hold times for slow memories and peripherals. |
|              | <ul> <li>LCSn and LWE are negated normally.</li> <li>LCSn and LWE are negated one quarter of a bus clock cycle earlier.</li> </ul>                                                                                                                                                                                                          |
|              |                                                                                                                                                                                                                                                                                                                                             |
| 21–22<br>ACS | Address to chip-select setup. Determines the delay of the $\overline{\text{LCSn}}$ assertion relative to the address change when the external memory access is handled by the GPCM. At system reset, OR0[ACS] = 11.                                                                                                                         |
|              | 00                                                                                                                                                                                                                                                                                                                                          |
|              | 01 Reserved.                                                                                                                                                                                                                                                                                                                                |
|              | 10  TCSn is output one quarter bus clock cycle after the address lines.                                                                                                                                                                                                                                                                     |
|              | 11  TCSn is output one half bus clock cycle after the address lines.                                                                                                                                                                                                                                                                        |
| 23<br>XACS   | Extra address to chip-select setup. Setting this bit increases the delay of the $\overline{\text{LCSn}}$ assertion relative to the address change when the external memory access is handled by the GPCM. After a system reset, $ORO[XACS] = 1$ .                                                                                           |
|              | Address to chip-select setup is determined by ORx[ACS] .                                                                                                                                                                                                                                                                                    |
|              | 1 Address to chip-select setup is extended (see Table 12-190 and Table 12-191 ).                                                                                                                                                                                                                                                            |
| 24–27<br>SCY | Cycle length in bus clocks. Determines the number of wait states inserted in the bus cycle, when the GPCM handles the external memory access. Thus it is the main parameter for determining cycle length. The total cycle length depends on other timing attribute settings. After a system reset, OR0[SCY] = 1111.                         |
|              | 0000 No wait states                                                                                                                                                                                                                                                                                                                         |
|              | 0001 1 bus clock cycle wait state                                                                                                                                                                                                                                                                                                           |
|              |                                                                                                                                                                                                                                                                                                                                             |
|              | 1111 15 bus clock cycle wait states                                                                                                                                                                                                                                                                                                         |
| 28<br>SETA   | External address termination.                                                                                                                                                                                                                                                                                                               |
|              | O Access is terminated internally by the memory controller unless the external device asserts LGTA earlier to terminate the access.                                                                                                                                                                                                         |
|              | 1 Access is terminated externally by asserting the LGTA external pin. (Only LGTA can terminate the access).                                                                                                                                                                                                                                 |
| 29<br>TRLX   | Timing relaxed. Modifies the settings of timing parameters for slow memories or peripherals.                                                                                                                                                                                                                                                |
|              | 0 Normal timing is generated by the GPCM.                                                                                                                                                                                                                                                                                                   |
|              | 1 Relaxed timing on the following parameters:                                                                                                                                                                                                                                                                                               |
|              | <ul> <li>Adds an additional cycle between the address and control signals (only if ACS is not equal to<br/>00).</li> </ul>                                                                                                                                                                                                                  |
|              | <ul> <li>Doubles the number of wait states specified by SCY, providing up to 30 wait states.</li> </ul>                                                                                                                                                                                                                                     |
|              | <ul> <li>Works in conjunction with EHTR to extend hold time on read accesses.</li> </ul>                                                                                                                                                                                                                                                    |
|              | <ul> <li>LCSn (only if ACS is not equal to 00) and LWE signals are negated one cycle earlier during<br/>writes.</li> </ul>                                                                                                                                                                                                                  |
| 30<br>EHTR   | Extended hold time on read accesses. Indicates with TRLX how many cycles are inserted between a read access from the current bank and the next access.                                                                                                                                                                                      |

#### **eLBC\_ORg0** field descriptions (continued)

| Field     | Description                                                                                                                                                                         |                                                                                                                                                                                                  |                                                                                   |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
|           |                                                                                                                                                                                     | Table 12-7. TRLX and EHTR                                                                                                                                                                        |                                                                                   |  |
|           | TRLX EHTR Meaning                                                                                                                                                                   |                                                                                                                                                                                                  |                                                                                   |  |
|           | 0                                                                                                                                                                                   | 0                                                                                                                                                                                                | The memory controller generates normal timing. No additional cycles are inserted. |  |
|           | 0                                                                                                                                                                                   | 1                                                                                                                                                                                                | 1 idle clock cycle is inserted.                                                   |  |
|           | 1                                                                                                                                                                                   | 0                                                                                                                                                                                                | 4 idle clock cycles are inserted.                                                 |  |
|           | 1                                                                                                                                                                                   | 1                                                                                                                                                                                                | 8 idle clock cycles are inserted.                                                 |  |
|           |                                                                                                                                                                                     |                                                                                                                                                                                                  |                                                                                   |  |
| 31<br>EAD | External address latch delay. Allow extra bus clock cycles when using external address latch (LALE).  O No additional bus clock cycles (LALE asserted for one bus clock cycle only) |                                                                                                                                                                                                  |                                                                                   |  |
|           | 1 Extra bus c                                                                                                                                                                       | No additional bus clock cycles (LALE asserted for one bus clock cycle only)      Extra bus clock cycles are added (LALE is asserted for the number of bus clock cycles specified by LCRR[EADC]). |                                                                                   |  |

## 12.3.3 Options register 0 layout for FCM Mode (eLBC\_ORf0)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

- GPCM mode
- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the FCM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

Table 12-9. Reset value of OR0 Register

| Boot Source                    | OR0 Reset Value |
|--------------------------------|-----------------|
| FCM (small page NAND Flash)    | 0000_03AE       |
| FCM (large page NAND Flash)    | 0000_07AE       |
| GPCM                           | 0000_0FF7       |
| eLBC not used as a boot source | 0000_0F07       |

The address mask field of the option registers (OR n [AM]) masks up to 17 corresponding BR n [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-10. Memory Bank Sizes in Relation to Address Mask

| AM                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0      | 512 Mbytes       |
| 1111_0000_0000_0      | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_10000_0     | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_11100_0     | 256 Kbytes       |
| 1111_1111_1110_0      | 128 Kbytes       |
| 1111_1111_1111_0      | 64 Kbytes        |
| 1111_1111_1111_1      | 32 Kbytes        |







<sup>\*</sup> Notes:

• AM field: See Table "Reset value of OR0 Register" above for the OR0 reset value. All other option registers have all bits cleared.

### eLBC\_ORf0 field descriptions

| Field                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                | Description                                                    |  |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|--|
| 0–16<br>AM                                                   | FCM address mask. Masks corresponding BRn bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map.  O Corresponding address bits are masked.  Corresponding address bits are used in the comparison between base and transaction addresses. |                                                                |                                                                |  |
| 17–18<br>-                                                   | This fiel<br>Reserve                                                                                                                                                                                                                                                                                                                                                                                                                        | d is rese<br>ed                                                | rved.                                                          |  |
| 19<br>BCTLD                                                  | 0 LBC                                                                                                                                                                                                                                                                                                                                                                                                                                       | ,,                                                             |                                                                |  |
| 20<br>-                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                           | This field is reserved. Reserved                               |                                                                |  |
| 21<br>PGS                                                    | <ul> <li>NAND Flash EEPROM page size, buffer size, and block size.</li> <li>Page size of 512 main area bytes plus 16 spare area bytes (small page devices); FCM RAM buffers are 1 Kbyte each; Flash block size of 16 Kbytes.</li> <li>Page size of 2048 main area bytes plus 64 spare area bytes (large page devices); FCM RAM buffers are 4 Kbytes each; Flash block size of 128 Kbytes.</li> </ul>                                        |                                                                |                                                                |  |
| 22<br>CSCT                                                   | Chip select to command time. Determines how far in advance \(\overline{LCSn}\) is asserted prior to any bus activity during a NAND Flash access handled by the FCM. This helps meet chip-select setup times for slow memories.  Table 12-15. TRLX and CSCT                                                                                                                                                                                  |                                                                |                                                                |  |
|                                                              | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                        | CSCT                                                           | Meaning                                                        |  |
|                                                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                              | The chip-select is asserted 1 clock cycle before any command.  |  |
| 0 1 The chip-select is asserted 4 clock cycles before any co |                                                                                                                                                                                                                                                                                                                                                                                                                                             | The chip-select is asserted 4 clock cycles before any command. |                                                                |  |
|                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                              | The chip-select is asserted 2 clock cycles before any command. |  |
|                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                                                              | The chip-select is asserted 8 clock cycles before any command. |  |
|                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                |                                                                |  |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eLBC\_ORf0 field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                      |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23<br>CST    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | p time. Determines the delay of <a href="https://www.ne.external.ne.org/rable-12-14">FFWE assertion relative to the command, address, or dat ne external memory access is handled by the FCM.  Table 12-14. TRLX and CST</a>         |
|              | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Meaning                                                                                                                                                                                                                              |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is asserted coincident with any command.                                                                                                                                                                            |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is asserted 0.25 clock cycles after any command, address, or data.                                                                                                                                                  |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is asserted 0.5 clock cycles after any command, address, or data.                                                                                                                                                   |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is asserted 1 clock cycle after any command, address, or data.                                                                                                                                                      |
| 24<br>CHT    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | e exterr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | time. Determines the LFWE negation prior to the command, address, or data change nal memory access is handled by the FCM.  Table 12-13. TRLX and CHT                                                                                 |
|              | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | СНТ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Meaning                                                                                                                                                                                                                              |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is negated 0.5 clock cycles before any command, address, or data change.                                                                                                                                            |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is negated 1 clock cycle before any command, address, or data change.                                                                                                                                               |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is negated 1.5 clock cycles before any command, address, or data change.                                                                                                                                            |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The write-enable is negated 2 clock cycles before any command, address, or data change.                                                                                                                                              |
| 25–27<br>SCY | <ul> <li>Cycle length in bus clocks. Determines the following:</li> <li>the number of wait states inserted in command, address, or data transfer bus cycles, when the FCN handles the external memory access. Thus it is the main parameter for determining cycle length. The total cycle length depends on other timing attribute settings.</li> <li>the delay between command/address writes and data write cycles, or the delay between write cycle and read cycles from NAND Flash EEPROM. A delay of 4x(2+SCY) clock cycles (TRLX = 0) or 8x(2+SCY) clock cycles (TRLX = 1) is inserted between the last write and the first data transfer to/from NAND Flash devices.</li> <li>the delay between a command write and the first sample point of the RDY/ BSY pin (connected to LFRB). LFRB is not sampled until 8x(2+SCY) clock cycles (TRLX = 0) or 16x(2+SCY) clock cycles (TRLX = 1) have elapsed following the command.</li> <li>No extra wait states</li> <li>1 bus clock cycle wait state</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                      |
|              | 000 N<br>001 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RLX = lo extra bus clo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1) have elapsed following the command.  wait states  ck cycle wait state                                                                                                                                                             |
| 28<br>RST    | 000 N<br>001 1<br><br>111 7<br>Read se<br>externa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RLX = lo extra bus clo bus clo tup time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | wait states  ck cycle wait states  ck cycle wait states  e. Determines the delay of LFRE assertion relative to sampling of read data when the ry access is handled by the FCM.  Table 12-12. TRLX and RST                            |
|              | 000 N<br>001 1<br><br>111 7<br>Read se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | In the second se | wait states ck cycle wait state ck cycle wait states ck cycle wait states ce. Determines the delay of LFRE assertion relative to sampling of read data when the ry access is handled by the FCM.  Table 12-12. TRLX and RST  Meaning |
|              | 000 N<br>001 1<br><br>111 7<br>Read se<br>externa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RLX = lo extra bus clo bus clo tup time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | wait states  ck cycle wait states  ck cycle wait states  e. Determines the delay of LFRE assertion relative to sampling of read data when the ry access is handled by the FCM.  Table 12-12. TRLX and RST                            |

#### **eLBC\_ORf0** field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |                                                                        |  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------|--|
|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Table 12-12. TRLX and RST (continued) |                                                                        |  |
|            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                     | The read-enable is asserted 0.5 clock cycles prior to any wait states. |  |
|            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1                                     | The read-enable is asserted 1 clock cycle prior to any wait states.    |  |
| 29<br>TRLX | Timing relaxed. Modifies the settings of timing parameters for slow memories.  O Normal timing is generated by the FCM.  Relaxed timing on the following parameters:  Doubles the number of clock cycles between LCSn assertion and commands.  Doubles the number of wait states specified by SCY, providing up to 14 wait states.  Works in conjunction with CST and RST to extend command/address/data setup times.  Adds one clock cycle to the command/address/data hold times.  Works in conjunction with CBT to extend the wait time for read/busy status sampling by 16 clock cycles.  Works in conjunction with EHTR to double hold time on read accesses. |                                       |                                                                        |  |
| 30<br>EHTR | Extended hold time on read accesses. Indicates with TRLX how many cycles are inserted between a read access from the current bank and the next access.  Table 12-11. TRLX and EHTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                       |                                                                        |  |
|            | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | EHTR                                  | Meaning                                                                |  |
|            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                     | 1 idle clock cycle is inserted.                                        |  |
|            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1                                     | 2 idle clock cycles are inserted.                                      |  |
|            | 1 0 4 idle clock cycles are inserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                       | 4 idle clock cycles are inserted.                                      |  |
|            | 1 1 8 idle clock cycles are inserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                       |                                                                        |  |
| 31<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                       |                                                                        |  |

# 12.3.4 Options register 0 layout for UPM Mode (eLBC\_ORu0)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

- GPCM mode
- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the UPM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

Table 12-17. Reset value of OR0 Register

| Boot Source                    | OR0 Reset Value |
|--------------------------------|-----------------|
| FCM (small page NAND Flash)    | 0000_03AE       |
| FCM (large page NAND Flash)    | 0000_07AE       |
| GPCM                           | 0000_0FF7       |
| eLBC not used as a boot source | 0000_0F07       |

The address mask field of the option registers (OR n [AM]) masks up to 17 corresponding BR n [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-18. Memory Bank Sizes in Relation to Address Mask

| АМ                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0      | 512 Mbytes       |
| 1111_0000_0000_0000_0 | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_1111_0000_0 | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_11100_0     | 256 Kbytes       |
| 1111_1111_1110_0      | 128 Kbytes       |
| 1111_1111_1111_0      | 64 Kbytes        |
| 1111_1111_1111_1      | 32 Kbytes        |

Address: 5000h base + 4h offset = 5004h



<sup>\*</sup> Notes:

### eLBC\_ORu0 field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>AM  | UPM address mask. Masks corresponding BR <i>n</i> bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. |
|             | 0 Corresponding address bits are masked.                                                                                                                                                                                                                                                                   |
|             | 1 The corresponding address bits are used in the comparison with address pins.                                                                                                                                                                                                                             |
| 17–18<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                           |
| 19<br>BCTLD | Buffer control disable. Disables assertion of LBCTL during access to the current memory bank.                                                                                                                                                                                                              |
|             | 0 LBCTL is asserted upon access to the current memory bank.                                                                                                                                                                                                                                                |
|             | LBCTL is not asserted upon access to the current memory bank.                                                                                                                                                                                                                                              |
| 20–22       | This field is reserved. Reserved                                                                                                                                                                                                                                                                           |
| 23<br>BI    | Burst inhibit. Indicates if this memory bank supports burst accesses.  O The bank supports burst accesses.                                                                                                                                                                                                 |
|             | 1 The bank does not support burst accesses. The selected UPM executes burst accesses as a series of single accesses.                                                                                                                                                                                       |
| 24–28<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                           |
| 29<br>TRLX  | Timing relaxed. Works in conjunction with EHTR to extend hold time on read accesses.                                                                                                                                                                                                                       |
| 30<br>EHTR  | Extended hold time on read accesses. Indicates with TRLX how many cycles are inserted between a read access from the current bank and the next access.                                                                                                                                                     |

AM field: See Table "Reset value of OR0 Register" above for the OR0 reset value. All other option registers have all bits cleared.

## eLBC\_ORu0 field descriptions (continued)

| Field     | Description                                                                                          |                                                                                                                   |                                                                                   |  |  |
|-----------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|
|           |                                                                                                      |                                                                                                                   | Table 12-19. TRLX and EHTR                                                        |  |  |
|           | TRLX                                                                                                 | TRLX EHTR Meaning                                                                                                 |                                                                                   |  |  |
|           | 0                                                                                                    | 0                                                                                                                 | The memory controller generates normal timing. No additional cycles are inserted. |  |  |
|           | 0                                                                                                    | 1                                                                                                                 | 1 idle clock cycle is inserted.                                                   |  |  |
|           | 1                                                                                                    | 0                                                                                                                 | 4 idle clock cycles are inserted.                                                 |  |  |
|           | 1                                                                                                    | 1                                                                                                                 | 8 idle clock cycles are inserted.                                                 |  |  |
|           |                                                                                                      |                                                                                                                   |                                                                                   |  |  |
| 31<br>EAD | External address latch delay. Allow extra bus clock cycles when using external address latch (LALE). |                                                                                                                   |                                                                                   |  |  |
|           | 0 No additional bus clock cycles (LALE asserted for one bus clock cycle only)                        |                                                                                                                   |                                                                                   |  |  |
|           |                                                                                                      | 1 Extra bus clock cycles are added (LALE is asserted for the number of bus clock cycles specified by LCRR[EADC]). |                                                                                   |  |  |

### 12.3.5 Base register n (eLBC\_BRn)

The base registers (BR n) contain the base address and address types for each memory bank. The memory controller uses this information to compare the address bus value with the current address accessed. Each register (bank) includes a memory attribute and selects the machine for memory operation handling. Note that after system reset, BR0[V] is set, BR1[V]-BR7[V] are cleared, and the value of BR0[PS] reflects the initial port size configured by the boot ROM location power-on configuration settings .



eLBC BRn field descriptions

| Field       | Description                                                                                                                                                                                                                                           |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>BA  | Base address. The upper 17 bits of each base register are compared to the address on the address bus to determine if the bus master is accessing a memory bank controlled by the memory controller. Used with the address mask bits OR <i>n</i> [AM]. |
| 17–18<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                      |
| 19–20<br>PS | Port size. Specifies the port size of this memory region. For BR0, PS is configured from the boot ROM location power-on reset configuration setting . For all other banks the value is reset to 00 (port size not defined).                           |
|             | 00 Reserved                                                                                                                                                                                                                                           |

### eLBC\_BRn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 01 8-bit (supported for GPCM, UPM, FCM)                                                                                                                                                                                                                                          |
|               | 10 16-bit (supported for GPCM, UPM)                                                                                                                                                                                                                                              |
|               | 11 Reserved                                                                                                                                                                                                                                                                      |
| 21–22<br>DECC | Specifies the method for data error checking.                                                                                                                                                                                                                                    |
|               | OD Data error checking disabled , but normal parity generation for GPCM and UPM . No ECC generation for FCM.                                                                                                                                                                     |
|               | 01 ECC checking is enabled, but ECC generation is disabled, for FCM on full-page transfers. Normal parity generation and checking for GPCM and UPM.                                                                                                                              |
|               | 10 ECC checking and generation are enabled for FCM on full-page transfers.                                                                                                                                                                                                       |
|               | 11 Reserved                                                                                                                                                                                                                                                                      |
| 23<br>WP      | Write protect.                                                                                                                                                                                                                                                                   |
|               | 0 Read and write accesses are allowed.                                                                                                                                                                                                                                           |
|               | 1 Only read accesses are allowed. The memory controller does not assert LCSn on write cycles to this memory bank. LTESR[WP] is set (if WP is set) if a write to this memory bank is attempted, and a local bus error interrupt is generated (if enabled), terminating the cycle. |
| 24–26         | Machine select. Specifies the machine to use for handling memory operations.                                                                                                                                                                                                     |
| MSEL          | 000 GPCM (possible reset value)                                                                                                                                                                                                                                                  |
|               | 001 FCM (possible reset value)                                                                                                                                                                                                                                                   |
|               | 010 Reserved                                                                                                                                                                                                                                                                     |
|               | 011 Reserved                                                                                                                                                                                                                                                                     |
|               | 100 UPMA                                                                                                                                                                                                                                                                         |
|               | 101 UPMB                                                                                                                                                                                                                                                                         |
|               | 110 UPMC                                                                                                                                                                                                                                                                         |
|               | 111 Reserved                                                                                                                                                                                                                                                                     |
| 27<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                 |
| 28–29         | This field is reserved. Reserved                                                                                                                                                                                                                                                 |
| 30            | This field is reserved. Reserved                                                                                                                                                                                                                                                 |
| 31            | Valid bit. Indicates that the contents of the BR <i>n</i> and OR <i>n</i> pair are valid. LCSn does not assert unless V is                                                                                                                                                       |
| V             | set (an access to a region that has no valid bit set may cause a bus time-out). After a system reset, only BR0[V] is set.                                                                                                                                                        |
|               | 0 This bank is invalid.                                                                                                                                                                                                                                                          |
|               | 1 This bank is valid.                                                                                                                                                                                                                                                            |

# 12.3.6 Options register n layout for GPCM Mode (eLBC\_ORgn)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

• GPCM mode

- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the GPCM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

 Boot Source
 OR0 Reset Value

 FCM (small page NAND Flash)
 0000\_03AE

 FCM (large page NAND Flash)
 0000\_07AE

 GPCM
 0000\_0FF7

 eLBC not used as a boot source
 0000\_0F07

Table 12-23. Reset value of OR0 Register

The address mask field of the option registers (OR n [AM]) masks up to 17 corresponding BR n [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-24. Memory Bank Sizes in Relation to Address Mask

| АМ                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0000_0 | 512 Mbytes       |
| 1111_0000_0000_0000_0 | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_1111_0000_0 | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_1111_1100_0 | 256 Kbytes       |

### Table 12-24. Memory Bank Sizes in Relation to Address Mask (continued)

| AM               | Memory Bank Size |
|------------------|------------------|
| 1111_1111_1110_0 | 128 Kbytes       |
| 1111_1111_1111_0 | 64 Kbytes        |
| 1111_1111_1111_1 | 32 Kbytes        |





#### eLBC\_ORgn field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>AM   | GPCM address mask. Masks corresponding BRn bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. |
|              | 0 Corresponding address bits are masked and therefore don't care for address checking.                                                                                                                                                                                                              |
|              | 1 Corresponding address bits are used in the comparison between base and transaction addresses.                                                                                                                                                                                                     |
| 17–18<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                    |
| 19<br>BCTLD  | Buffer control disable. Disables assertion of LBCTL during access to the current memory bank.                                                                                                                                                                                                       |
|              | 0 LBCTL is asserted upon access to the current memory bank.                                                                                                                                                                                                                                         |
|              | LBCTL is not asserted upon access to the current memory bank.                                                                                                                                                                                                                                       |
| 20<br>CSNT   | Chip select negation time. Determines when LCSn and LWE are negated during an external memory write access handled by the GPCM, provided that ACS ≠ 00 (when ACS = 00, only LWE is affected by the setting of CSNT). This helps meet address/data hold times for slow memories and peripherals.     |
|              | 0 LCSn and LWE are negated normally.                                                                                                                                                                                                                                                                |
|              | 1 LCSn and LWE are negated one quarter of a bus clock cycle earlier.                                                                                                                                                                                                                                |
| 21–22<br>ACS | Address to chip-select setup. Determines the delay of the LCSn assertion relative to the address change when the external memory access is handled by the GPCM. At system reset, OR0[ACS] = 11.                                                                                                     |
|              | 00 LCSn is output at the same time as the address lines. Note that this overrides the value of CSNT such that CSNT = 0.                                                                                                                                                                             |
|              | 01 Reserved.                                                                                                                                                                                                                                                                                        |

## eLBC\_ORgn field descriptions (continued)

| Field        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                   | Description                                                                                                  |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------|--|--|
|              | 10 LCSn is out                                                                                                                                                                                                                                                                                                                                                                                                                                                       | put one quarter   | bus clock cycle after the address lines.                                                                     |  |  |
|              | 11 LCSn is out                                                                                                                                                                                                                                                                                                                                                                                                                                                       | put one half bus  | clock cycle after the address lines.                                                                         |  |  |
| 23<br>XACS   | Extra address to chip-select setup. Setting this bit increases the delay of the $\overline{\text{LCSn}}$ assertion relative to the address change when the external memory access is handled by the GPCM. After a system reset, OR0[XACS] = 1.                                                                                                                                                                                                                       |                   |                                                                                                              |  |  |
|              | 0 Address to c                                                                                                                                                                                                                                                                                                                                                                                                                                                       | hip-select setup  | is determined by ORx[ACS] .                                                                                  |  |  |
|              | 1 Address to c                                                                                                                                                                                                                                                                                                                                                                                                                                                       | hip-select setup  | is extended (see Table 12-190 and Table 12-191 ).                                                            |  |  |
| 24–27<br>SCY | Cycle length in bus clocks. Determines the number of wait states inserted in the bus cycle, when the GPCM handles the external memory access. Thus it is the main parameter for determining cycle leterate total cycle length depends on other timing attribute settings. After a system reset, OR0[SCY] =                                                                                                                                                           |                   |                                                                                                              |  |  |
|              | 0000 No wait s                                                                                                                                                                                                                                                                                                                                                                                                                                                       | tates             |                                                                                                              |  |  |
|              | 0001 1 bus clo                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ck cycle wait sta | te                                                                                                           |  |  |
|              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                   |                                                                                                              |  |  |
|              | 1111 15 bus cl                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ock cycle wait st | ates                                                                                                         |  |  |
| 28           | External address                                                                                                                                                                                                                                                                                                                                                                                                                                                     | termination.      |                                                                                                              |  |  |
| SETA         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | minated internal  | ly by the memory controller unless the external device asserts LGTA ss.                                      |  |  |
|              | 1 Access is ter access).                                                                                                                                                                                                                                                                                                                                                                                                                                             | minated externa   | lly by asserting the $\overline{\text{LGTA}}$ external pin. (Only $\overline{\text{LGTA}}$ can terminate the |  |  |
| 29<br>TRLX   | 0 Normal timin                                                                                                                                                                                                                                                                                                                                                                                                                                                       | g is generated b  |                                                                                                              |  |  |
|              | <ul> <li>1 Relaxed timing on the following parameters:</li> <li>Adds an additional cycle between the address and control signals (only if ACS is not equal to 00).</li> <li>Doubles the number of wait states specified by SCY, providing up to 30 wait states.</li> <li>Works in conjunction with EHTR to extend hold time on read accesses.</li> <li>LCSn (only if ACS is not equal to 00) and LWE signals are negated one cycle earlier during writes.</li> </ul> |                   |                                                                                                              |  |  |
| 30<br>EHTR   | Extended hold time on read accesses. Indicates with TRLX how many cycles are inserted between a access from the current bank and the next access.  Table 12-25. TRLX and EHTR                                                                                                                                                                                                                                                                                        |                   |                                                                                                              |  |  |
|              | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EHTR              | Meaning                                                                                                      |  |  |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                 | The memory controller generates normal timing. No additional cycles are inserted.                            |  |  |
|              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                 | 1 idle clock cycle is inserted.                                                                              |  |  |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                 | 4 idle clock cycles are inserted.                                                                            |  |  |
|              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                 | 8 idle clock cycles are inserted.                                                                            |  |  |
| 31<br>EAD    | External address latch delay. Allow extra bus clock cycles when using external address latch (LALE).  O No additional bus clock cycles (LALE asserted for one bus clock cycle only)  Extra bus clock cycles are added (LALE is asserted for the number of bus clock cycles specified by                                                                                                                                                                              |                   |                                                                                                              |  |  |
|              | LCRR[EADC                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5]).              |                                                                                                              |  |  |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 12.3.7 Options register n layout for FCM Mode (eLBC\_ORfn)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

- GPCM mode
- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the FCM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

 Boot Source
 OR0 Reset Value

 FCM (small page NAND Flash)
 0000\_03AE

 FCM (large page NAND Flash)
 0000\_07AE

 GPCM
 0000\_0FF7

 eLBC not used as a boot source
 0000\_0F07

Table 12-31. Reset value of OR0 Register

The address mask field of the option registers (OR n [AM]) masks up to 17 corresponding BR n [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-32. Memory Bank Sizes in Relation to Address Mask

| АМ                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0000_0 | 512 Mbytes       |
| 1111_0000_0000_0000_0 | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |

Table 12-32. Memory Bank Sizes in Relation to Address Mask (continued)

| AM                    | Memory Bank Size |
|-----------------------|------------------|
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_10000_0     | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_11100_0     | 256 Kbytes       |
| 1111_1111_1110_0      | 128 Kbytes       |
| 1111_1111_1111_0      | 64 Kbytes        |
| 1111_1111_1111_1      | 32 Kbytes        |





eLBC\_ORfn field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>AM | FCM address mask. Masks corresponding BRn bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. |
|            | <ul> <li>Corresponding address bits are masked.</li> <li>Corresponding address bits are used in the comparison between base and transaction addresses.</li> </ul>                                                                                                                                  |

## eLBC\_ORfn field descriptions (continued)

| Field       |                                                                                                                                                                                               |                                                                                                                                                                                                                                             | Description                                                                                                                   |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 17–18<br>-  | This fiel                                                                                                                                                                                     | ld is rese<br>ed                                                                                                                                                                                                                            | erved.                                                                                                                        |  |  |  |
| 19<br>BCTLD | Buffer control disable. Disables assertion of LBCTL during access to the current memory bank.                                                                                                 |                                                                                                                                                                                                                                             |                                                                                                                               |  |  |  |
| DOTED       | 1                                                                                                                                                                                             |                                                                                                                                                                                                                                             | sserted upon access to the current memory bank. ot asserted upon access to the current memory bank.                           |  |  |  |
| 20          |                                                                                                                                                                                               | This field is reserved. Reserved                                                                                                                                                                                                            |                                                                                                                               |  |  |  |
| 21<br>PGS   | NAND I                                                                                                                                                                                        | Flash EE                                                                                                                                                                                                                                    | PROM page size, buffer size, and block size.                                                                                  |  |  |  |
| 1 40        |                                                                                                                                                                                               |                                                                                                                                                                                                                                             | f 512 main area bytes plus 16 spare area bytes (small page devices); FCM RAM buffers each; Flash block size of 16 Kbytes.     |  |  |  |
|             | 1 Pag                                                                                                                                                                                         | ge size o                                                                                                                                                                                                                                   | f 2048 main area bytes plus 64 spare area bytes (large page devices); FCM RAM buffers s each; Flash block size of 128 Kbytes. |  |  |  |
| 22<br>CSCT  | during a                                                                                                                                                                                      | Chip select to command time. Determines how far in advance LCSn is asserted prior to any bus activity during a NAND Flash access handled by the FCM. This helps meet chip-select setup times for slow memories.  Table 12-37. TRLX and CSCT |                                                                                                                               |  |  |  |
|             | TRLX                                                                                                                                                                                          | CSCT                                                                                                                                                                                                                                        | Meaning                                                                                                                       |  |  |  |
|             | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The chip-select is asserted 1 clock cycle before any command.                                                                 |  |  |  |
|             | 0                                                                                                                                                                                             | 1                                                                                                                                                                                                                                           | The chip-select is asserted 4 clock cycles before any command.                                                                |  |  |  |
|             | 1                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The chip-select is asserted 2 clock cycles before any command.                                                                |  |  |  |
|             | 1                                                                                                                                                                                             | 1                                                                                                                                                                                                                                           | The chip-select is asserted 8 clock cycles before any command.                                                                |  |  |  |
| 23<br>CST   | Command setup time. Determines the delay of LFWE assertion relative to the command, address, or data change when the external memory access is handled by the FCM.  Table 12-36. TRLX and CST |                                                                                                                                                                                                                                             |                                                                                                                               |  |  |  |
|             | TRLX                                                                                                                                                                                          | CST                                                                                                                                                                                                                                         | Meaning                                                                                                                       |  |  |  |
|             | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The write-enable is asserted coincident with any command.                                                                     |  |  |  |
|             | 0                                                                                                                                                                                             | 1                                                                                                                                                                                                                                           | The write-enable is asserted 0.25 clock cycles after any command, address, or data.                                           |  |  |  |
|             | 1                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The write-enable is asserted 0.5 clock cycles after any command, address, or data.                                            |  |  |  |
|             | 1                                                                                                                                                                                             | 1                                                                                                                                                                                                                                           | The write-enable is asserted 1 clock cycle after any command, address, or data.                                               |  |  |  |
| 24<br>CHT   | Command hold time. Determines the LFWE negation prior to the command, address, or data change when the external memory access is handled by the FCM.  Table 12-35. TRLX and CHT               |                                                                                                                                                                                                                                             |                                                                                                                               |  |  |  |
|             | TRLX                                                                                                                                                                                          | СНТ                                                                                                                                                                                                                                         | Meaning                                                                                                                       |  |  |  |
|             | 0                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The write-enable is negated 0.5 clock cycles before any command, address, or data change.                                     |  |  |  |
|             | 0                                                                                                                                                                                             | 1                                                                                                                                                                                                                                           | The write-enable is negated 1 clock cycle before any command, address, or data change.                                        |  |  |  |
|             | 1                                                                                                                                                                                             | 0                                                                                                                                                                                                                                           | The write-enable is negated 1.5 clock cycles before any command, address, or data change.                                     |  |  |  |

## eLBC\_ORfn field descriptions (continued)

|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|             | Table 12-35. TRLX and CHT (continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                                                                                | The write-enable is negated 2 clock cycles before any command, address, or data change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 25–27       | Cycle le                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | nath in t                                                                                                                                        | ous clocks. Determines the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| SCY         | <ul> <li>the number of wait states inserted in command, address, or data transfer bus cycles, when the FCM handles the external memory access. Thus it is the main parameter for determining cycle length. The total cycle length depends on other timing attribute settings.</li> <li>the delay between command/address writes and data write cycles, or the delay between write cycles and read cycles from NAND Flash EEPROM. A delay of 4x(2+SCY) clock cycles (TRLX = 0) or 8x(2+SCY) clock cycles (TRLX = 1) is inserted between the last write and the first data transfer to/ from NAND Flash devices.</li> <li>the delay between a command write and the first sample point of the RDY/ BSY pin (connected to LFRB). LFRB is not sampled until 8x(2+SCY) clock cycles (TRLX = 0) or 16x(2+SCY) clock cycles (TRLX = 1) have elapsed following the command.</li> </ul> |                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                  | wait states                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|             | 001 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | bus clo                                                                                                                                          | ck cycle wait state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | bus slav                                                                                                                                         | ak ayala wait atataa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| 28          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                  | ck cycle wait states                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| 26<br>RST   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Read setup time. Determines the delay of LFRE assertion relative to sampling of read data when the external memory access is handled by the FCM. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                  | Table 12-34. TRLX and RST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|             | TRLX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RST                                                                                                                                              | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                | The read-enable is asserted 0.75 clock cycles prior to any wait states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                | The read-enable is asserted 0.75 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                  | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                                                                                | The read-enable is asserted 1 clock cycle prior to any wait states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| 29<br>TRI X | 0 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 0 1                                                                                                                                            | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 29<br>TRLX  | 0<br>1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1<br>0<br>1                                                                                                                                      | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|             | Timing r  O Nor  Rela                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 0 1 1 relaxed. mal timir axed tim • Doubl • Works • Adds • Works cycles                                                                        | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.  Modifies the settings of timing parameters for slow memories.  In gis generated by the FCM.  In ging on the following parameters:  In es the number of clock cycles between LCSn assertion and commands.  In es the number of wait states specified by SCY, providing up to 14 wait states.  In conjunction with CST and RST to extend command/address/data setup times.  In conjunction with CBT to extend the wait time for read/busy status sampling by 16 clocks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|             | Timing I  O Nor Rela                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | relaxed. mal timinaxed tim Doubl Doubl Works Adds Works Works                                                                                    | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.  Modifies the settings of timing parameters for slow memories.  In g is generated by the FCM.  In g on the following parameters:  In es the number of clock cycles between LCSn assertion and commands.  In es the number of wait states specified by SCY, providing up to 14 wait states.  In conjunction with CST and RST to extend command/address/data setup times.  In conjunction with CBT to extend the wait time for read/busy status sampling by 16 clocks.  In conjunction with CBT to double hold time on read accesses.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| TRLX        | Timing r  O Nor 1 Rela                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | relaxed. mal timir axed tim Doubl Doubl Works Adds Works Cycles Works                                                                            | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.  Modifies the settings of timing parameters for slow memories.  In gis generated by the FCM.  In ging on the following parameters:  In es the number of clock cycles between LCSn assertion and commands.  In es the number of wait states specified by SCY, providing up to 14 wait states.  In conjunction with CST and RST to extend command/address/data setup times.  In conjunction with CBT to extend the wait time for read/busy status sampling by 16 clocks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| TRLX<br>30  | Timing r  O Nor 1 Rela                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1 0 1 1 relaxed. mal timir axed time Double Works Yorks yeles works and hold tiffrom the                                                         | The read-enable is asserted 1 clock cycle prior to any wait states.  The read-enable is asserted 0.5 clock cycles prior to any wait states.  The read-enable is asserted 1 clock cycle prior to any wait states.  Modifies the settings of timing parameters for slow memories.  In g is generated by the FCM.  In g is generated by wait states.  In g is generated by the FCM.  In g is generated by wait st |  |  |  |

#### **eLBC\_ORf***n* field descriptions (continued)

| Field   |            | Description                            |                                   |  |  |  |
|---------|------------|----------------------------------------|-----------------------------------|--|--|--|
|         |            | Table 12-33. TRLX and EHTR (continued) |                                   |  |  |  |
|         | TRLX       | EHTR                                   | Meaning                           |  |  |  |
|         | 0          | 1                                      | 2 idle clock cycles are inserted. |  |  |  |
|         | 1          | 0                                      | 4 idle clock cycles are inserted. |  |  |  |
|         | 1          | 1                                      | 8 idle clock cycles are inserted. |  |  |  |
|         |            |                                        |                                   |  |  |  |
| 31<br>- | This field |                                        | rved.                             |  |  |  |

## 12.3.8 Options register n layout for UPM Mode (eLBC\_ORun)

The OR n registers define the sizes of memory banks and access attributes. The OR n attribute bits support the following three modes of operation as defined by BR n [MSEL]:

- GPCM mode
- FCM mode
- UPM mode

The OR *n* registers are interpreted differently depending on which of the three machine types is selected for that bank; this section describes the interpretation when the UPM controls bank n.

Because bank 0 can be used to boot, the reset value of OR0 may be different depending on power-on configuration options, specifically the cfg\_rom\_loc power-on-reset pins.

Table 12-47. Reset value of OR0 Register

| Boot Source                    | OR0 Reset Value |
|--------------------------------|-----------------|
| FCM (small page NAND Flash)    | 0000_03AE       |
| FCM (large page NAND Flash)    | 0000_07AE       |
| GPCM                           | 0000_0FF7       |
| eLBC not used as a boot source | 0000_0F07       |

The address mask field of the option registers (OR *n* [AM]) masks up to 17 corresponding BR *n* [BA] fields. The 15 LSBs of the 32-bit internal transaction address do not participate in bank address matching in selecting a bank for access. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. The table below shows memory bank sizes from 32 Kbytes to 4 Gbytes.

Table 12-48. Memory Bank Sizes in Relation to Address Mask

| AM                    | Memory Bank Size |
|-----------------------|------------------|
| 0000_0000_0000_0      | 4 Gbytes         |
| 1000_0000_0000_0      | 2 Gbytes         |
| 1100_0000_0000_0      | 1 Gbyte          |
| 1110_0000_0000_0      | 512 Mbytes       |
| 1111_0000_0000_0      | 256 Mbytes       |
| 1111_1000_0000_0000_0 | 128 Mbytes       |
| 1111_1100_0000_0000_0 | 64 Mbytes        |
| 1111_1110_0000_0000_0 | 32 Mbytes        |
| 1111_1111_0000_0000_0 | 16 Mbytes        |
| 1111_1111_1000_0000_0 | 8 Mbytes         |
| 1111_1111_1100_0000_0 | 4 Mbytes         |
| 1111_1111_1110_0000_0 | 2 Mbytes         |
| 1111_1111_10000_0     | 1 Mbyte          |
| 1111_1111_1000_0      | 512 Kbytes       |
| 1111_1111_11100_0     | 256 Kbytes       |
| 1111_1111_1110_0      | 128 Kbytes       |
| 1111_1111_1111_0      | 64 Kbytes        |
| 1111_1111_1111_1      | 32 Kbytes        |





eLBC\_ORun field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>AM | UPM address mask. Masks corresponding BR <i>n</i> bits. Masking address bits independently allows external devices of different size address ranges to be used. Address mask bits can be set or cleared in any order in the field, allowing a resource to reside in more than one area of the address map. |
|            | <ul> <li>Corresponding address bits are masked.</li> <li>The corresponding address bits are used in the comparison with address pins.</li> </ul>                                                                                                                                                           |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### eLBC\_ORun field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                          |                                       |                                                                                   |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------|--|--|--|
| 17–18<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                     |                                       |                                                                                   |  |  |  |
| 19<br>BCTLD | Buffer control disable. Disables assertion of LBCTL during access to the current memory bank.  0 LBCTL is asserted upon access to the current memory bank.  1 LBCTL is not asserted upon access to the current memory bank.                                                                          |                                       |                                                                                   |  |  |  |
| 20–22<br>-  | This fiel<br>Reserve                                                                                                                                                                                                                                                                                 | d is rese                             | erved.                                                                            |  |  |  |
| 23<br>BI    | 0 The                                                                                                                                                                                                                                                                                                | · · · · · · · · · · · · · · · · · · · |                                                                                   |  |  |  |
| 24–28       | This fiel<br>Reserve                                                                                                                                                                                                                                                                                 | d is rese                             | erved.                                                                            |  |  |  |
| 29<br>TRLX  | Timing i                                                                                                                                                                                                                                                                                             | relaxed.                              | Works in conjunction with EHTR to extend hold time on read accesses.              |  |  |  |
| 30<br>EHTR  | Extended hold time on read accesses. Indicates with TRLX how many cycles are inserted access from the current bank and the next access.  Table 12-49. TRLX and EHTR                                                                                                                                  |                                       |                                                                                   |  |  |  |
|             | TRLX                                                                                                                                                                                                                                                                                                 | EHTR                                  | Meaning                                                                           |  |  |  |
|             | 0                                                                                                                                                                                                                                                                                                    | 0                                     | The memory controller generates normal timing. No additional cycles are inserted. |  |  |  |
|             | 0                                                                                                                                                                                                                                                                                                    | 1                                     | 1 idle clock cycle is inserted.                                                   |  |  |  |
|             | 1                                                                                                                                                                                                                                                                                                    | 0                                     | 4 idle clock cycles are inserted.                                                 |  |  |  |
|             | 1                                                                                                                                                                                                                                                                                                    | 1                                     | 8 idle clock cycles are inserted.                                                 |  |  |  |
| 31<br>EAD   | External address latch delay. Allow extra bus clock cycles when using external address latch (LALE).  O No additional bus clock cycles (LALE asserted for one bus clock cycle only)  Extra bus clock cycles are added (LALE is asserted for the number of bus clock cycles specified by LCRR[EADC]). |                                       |                                                                                   |  |  |  |

# 12.3.9 UPM address register (eLBC\_MAR)

Address: 5000h base + 68h offset = 5068h



#### eLBC\_MAR field descriptions

| Field     | Description                                                                                          |
|-----------|------------------------------------------------------------------------------------------------------|
| 0–31<br>A | Address that can be output to the address signals under control of the AMX bits in the UPM RAM word. |

## 12.3.10 UPMn mode register (eLBC\_MnMR)

The UPM machine mode registers (MAMR, MBMR, and MCMR) contain the configuration for the three UPMs.





#### eLBC\_MnMR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 -   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                  |
| RFEN  | Refresh enable. Indicates that the UPM needs refresh services. This bit must be set for UPMA (refresh executor) if refresh services are required on any UPM assigned chip selects. If MAMR[RFEN] = 0, no refresh services can be provided, even if UPMB and/or UPMC have their RFEN bit set.  0 Refresh services are not required 1 Refresh services are required |

## eLBC\_MnMR field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2–3<br>OP     | Command opcode. Determines the command executed by the UPM <i>n</i> when a memory access hits a UPM assigned bank.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | 00 Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 01 Write to UPM array. On the next memory access that hits a UPM assigned bank, write the contents of the MDR into the RAM location pointed to by MAD. After the access, MAD is automatically incremented.                                                                                                                                                                                                                                                                                                                                             |
|               | 10 Read from UPM array. On the next memory access that hits a UPM assigned bank, read the contents of the RAM location pointed to by MAD into the MDR. After the access, MAD is automatically incremented.                                                                                                                                                                                                                                                                                                                                             |
|               | 11 Run pattern. On the next memory access that hits a UPM assigned bank, run the pattern written in the RAM array. The pattern run starts at the location pointed to by MAD and continues until the LAST bit is set in the RAM word.                                                                                                                                                                                                                                                                                                                   |
| 4<br>UWPL     | LUPWAIT polarity active low. Sets the polarity of the LUPWAIT pin when in UPM mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 0 LUPWAIT is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | 1 LUPWAIT is active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5–7<br>AM     | Address multiplex size. Determines how the address of the current memory cycle can be output on the address pins. This field is needed when interfacing with devices requiring row and column addresses multiplexed on the same pins. See Address multiplexing (AMX) for more information.                                                                                                                                                                                                                                                             |
|               | 000 Internal transaction address a[8:23] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 001 Internal transaction address a[7:22] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 010 Internal transaction address a[6:21] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 011 Internal transaction address a[5:20] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 100 Internal transaction address a[4:19] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 101 Internal transaction address a[3:18] driven on LA [ 16:31 ]; LAD[0:15] driven low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 110 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|               | 111 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8–9<br>DS     | Disable timer period. Guarantees a minimum time between accesses to the same memory bank controlled by UPM $n$ . The disable timer is turned on by the TODT bit in the RAM array word, and when expired, the UPM $n$ allows the machine access to handle a memory pattern to the same bank. Accesses to a different bank by the same UPM $n$ is also allowed. To avoid conflicts between successive accesses to different banks, the minimum pattern in the RAM array for a request serviced, should not be shorter than the period established by DS. |
|               | 00 1-bus clock cycle disable period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 01 2-bus clock cycle disable period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 10 3-bus clock cycle disable period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 11 4-bus clock cycle disable period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10–12<br>G0CL | General line 0 control. Determines which logical address line can be output to the LGPL0 pin when the UPM $n$ is selected to control the memory access.                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 000 A12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 001 A11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 010 A10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 011 A9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 100 A8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 101 A7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## eLBC\_MnMR field descriptions (continued)

|              | Description                                                                                                                                           |                                                                 |                             |                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------|-------------------------------|
|              | 110 A6                                                                                                                                                |                                                                 |                             |                               |
|              | 111 A5                                                                                                                                                |                                                                 |                             |                               |
| 13<br>GPL4   | LGPL4 output line disable. Determines how the LGPL4/LUPWAIT pin is controlled by the corresponding bits in the UPM <i>n</i> array. See Table 12-201 . |                                                                 |                             |                               |
|              |                                                                                                                                                       | Table 12-158. E                                                 | ffect of GPL4 Settir        | ngs                           |
|              | Value                                                                                                                                                 | LGPL4/LUPWAIT Pin                                               | Interpretation              | of UPM Word Bits              |
|              |                                                                                                                                                       | Function                                                        | G4T1/DLT3                   | G4T3/WAEN                     |
|              | 0                                                                                                                                                     | LGPL4 (output)                                                  | G4T1                        | G4T3                          |
|              | 1                                                                                                                                                     | LUPWAIT (input)                                                 | DLT3                        | WAEN                          |
|              |                                                                                                                                                       |                                                                 |                             |                               |
| 14–17<br>RLF |                                                                                                                                                       | Determines the number of times and pattern or when M x MR[OP] = |                             | will be executed for a burst- |
|              |                                                                                                                                                       | a panom or mion mix im ito j                                    | (                           |                               |
|              | 0000 16<br>0001 1                                                                                                                                     |                                                                 |                             |                               |
|              | 0010 2                                                                                                                                                |                                                                 |                             |                               |
|              | 0011 3                                                                                                                                                |                                                                 |                             |                               |
|              |                                                                                                                                                       |                                                                 |                             |                               |
|              | 1110 14                                                                                                                                               |                                                                 |                             |                               |
|              | 1111 15                                                                                                                                               |                                                                 |                             |                               |
| 18–21<br>WLF | Write loop field. Dor single-beat wri                                                                                                                 | Determines the number of times a<br>te pattern.                 | loop defined in the UPM $n$ | will be executed for a burst- |
|              | 0000 16                                                                                                                                               |                                                                 |                             |                               |
|              | 0001 1                                                                                                                                                |                                                                 |                             |                               |
|              | 0010 2                                                                                                                                                |                                                                 |                             |                               |
|              | 0011 3                                                                                                                                                |                                                                 |                             |                               |
|              | <br>1110 14                                                                                                                                           |                                                                 |                             |                               |
|              | 1111 15                                                                                                                                               |                                                                 |                             |                               |
| 22–25<br>TLF |                                                                                                                                                       | l. Determines the number of times                               | s a loop defined in the UPM | In will be executed for a     |
|              | 0000 16                                                                                                                                               |                                                                 |                             |                               |
|              | 0001 1                                                                                                                                                |                                                                 |                             |                               |
|              | 0010 2                                                                                                                                                |                                                                 |                             |                               |
|              | 0011 3                                                                                                                                                |                                                                 |                             |                               |
|              |                                                                                                                                                       |                                                                 |                             |                               |
|              | 1110 14<br>1111 15                                                                                                                                    |                                                                 |                             |                               |
| 26–31<br>MAD | Machine address                                                                                                                                       | . RAM address pointer for the con                               |                             |                               |
| <del>-</del> | n .                                                                                                                                                   |                                                                 |                             | J                             |

### 12.3.11 Memory refresh timer prescaler register (eLBC\_MRTPR)

The refresh timer prescaler register (MRTPR) is used to divide the platform clock to provide the UPM refresh timers clock.

Address: 5000h base + 84h offset = 5084h



#### eLBC\_MRTPR field descriptions

| Field      | Description                                                                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>PTP | Refresh timers prescaler. Determines the period of the refresh timers input clock. The platform clock is divided by PTP except when the value is 00000_0000, which represents the maximum divider of 256. |
| 8–31<br>-  | This field is reserved. Reserved                                                                                                                                                                          |

### 12.3.12 UPM data register (eLBC\_MDRu)

The memory data register (MDR) contains data written to or read from the RAM array for UPM read or write commands. MDR also contains data written to or read from an external NAND Flash EEPROM for FCM write address, write data, and read status commands. MDR must be set up before issuing a write command to the UPM, or before issuing a FCM operation sequence that uses MDR to source address or data bytes.

Address: 5000h base + 88h offset = 5088h



#### eLBC\_MDRu field descriptions

| Field | Description                                                                                            |
|-------|--------------------------------------------------------------------------------------------------------|
| 0–31  | D is the data to be read or written into the RAM array when a write or read command is supplied to the |
| D     | UPM (M $x$ MR[OP] = 01 or M $x$ MR[OP] = 10).                                                          |

### 12.3.13 FCM data register (eLBC\_MDRf)

The memory data register (MDR) contains data written to or read from the RAM array for UPM read or write commands. MDR also contains data written to or read from an external NAND Flash EEPROM for FCM write address, write data, and read status commands. MDR must be set up before issuing a write command to the UPM, or before issuing a FCM operation sequence that uses MDR to source address or data bytes.

Address: 5000h base + 88h offset = 5088h



#### eLBC\_MDRf field descriptions

| Field        | Description                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7<br>AS3   | AS3 is the fourth byte of address sent by a custom address write operation, or the fourth byte of data read from a read status operation. |
| 8–15<br>AS2  | AS2 is the third byte of address sent by a custom address write operation, or the third byte of data read from a read status operation.   |
| 16–23<br>AS1 | AS1 is the second byte of address sent by a custom address write operation, or the second byte of data read from a read status operation. |
| 24–31<br>AS0 | AS0 is the first byte of address sent by a custom address write operation, or the first byte of data read from a read status operation.   |

## 12.3.14 Special operation initiation register (eLBC\_LSOR)

The special operation initiation register (LSOR) is used by software to trigger a special operation on the indicated bank. Writing to LSOR activates a special operation on bank LSOR[BANK] provided that the bank is valid and controlled by a memory controller whose mode OP field is set to a value other than "normal operation." If eLBC is currently busy with a memory transaction, writing LSOR completes immediately, but the special operation request is queued until eLBC can service it. To avoid race conditions between software and a busy eLBC, registers that affect currently running special operation and LSOR must not be rewritten before a pending special operation has been completed. The UPM and FCM have different indications of when such special operations are completed. The behavior of eLBC is unpredictable if special operation modes are altered between LSOR being written and the relevant memory controller completing that access.

UPM special operation modes are set in registers M x MR[OP], see UPMn mode register (eLBC\_MnMR). FCM special operation modes are set in FMR[OP], see Flash mode register (eLBC\_FMR). Writing LSOR has the same effect as setting a special controller mode and performing a dummy access to a bank associated with the controller in question, but use of LSOR avoids changing settings for the address space occupied by the bank. More details of special operation sequences appear in UPM programming example (two sequential writes to the RAM array).





#### eLBC\_LSOR field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–28          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                             |
| 29–31<br>BANK | Bank on which a special operation is initiated. If the bank identified by BANK is marked valid (BRn[V] set) and the bank is controlled by a memory controller whose current mode OP is non-zero-or a special operation-eLBC will request the special operation to be activated on the selected bank when this field is written. Otherwise, writing this field has no effect. |
|               | <ul> <li>Bank 0 is triggered for special operation</li> <li>Bank 7 is triggered for special operation</li> </ul>                                                                                                                                                                                                                                                             |

### 12.3.15 UPM refresh timer (eLBC\_LURT)

The UPM refresh timer (LURT) generates a refresh request for all valid banks that selected a UPM machine and are refresh-enabled (M x MR[RFEN] = 1). Each time the timer expires, a qualified bank generates a refresh request using the selected UPM. The qualified banks rotate their requests.

Address: 5000h base + A0h offset = 50A0h



#### **eLBC\_LURT** field descriptions

| Field       | Description                                                                                                                                                                                                                                    |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>LURT | UPM refresh timer period. Determines, along with the timer prescaler (MRTPR), the timer period according to the following equation:                                                                                                            |
|             | $TimerPeriod = \frac{LURT}{\left(\frac{InputClock}{MRTPR[PTP]}\right)}$                                                                                                                                                                        |
|             | Example: For a 266-MHz system clock and a required service rate of 15.6 $\mu$ s, given MRTPR[PTP] = 32, the LURT value should be 128 decimal. 128/(266 MHz/32) = 15.4 $\mu$ s, which is less than the required service period of 15.6 $\mu$ s. |
|             | Note that the reset value (0x00) sets the maximum period to 256 x MRTPR[PTP] system clock cycles.                                                                                                                                              |
| 8–31<br>-   | This field is reserved. Reserved                                                                                                                                                                                                               |

### 12.3.16 Transfer error status register (eLBC\_LTESR)

The transfer error status register (LTESR) indicates the cause of an error or event. LTESR is a write-1-to-clear register. Reading LTESR occurs normally; however, write operations can clear but not set bits. A bit is cleared whenever the register is written, and the data in the corresponding bit location is a 1. For example, to clear only the write protect error bit (LTESR[WP]) without affecting other LTESR bits,  $0x0400\_0000$  should be written to the register. After any error/event reported by LTESR, LTEATR[V] must be cleared for LTESR to updated again. Note that error statuses are only reflected in LTESR if they have been enabled in LTEDR.

Address: 5000h base + B0h offset = 50B0h



**eLBC\_LTESR** field descriptions

| Field | Description          |
|-------|----------------------|
| 0     | Bus monitor time-out |
| BM    |                      |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eLBC\_LTESR field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                    |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|            | <ul> <li>No local bus monitor time-out occurred.</li> <li>Local bus monitor time-out occurred. No data beat was acknowledged on the bus within LBCR[BMT] x LBCR[BMTPS] bus clock cycles from the start of a transaction.</li> </ul>                                                                            |  |
| 1<br>FCT   | FCM command time-out  No FCM command time-out occurred.  A CW0, CW1, CW2, or CW3 command issued to FCM timed-out with respect to the timer configured by FMR[CWTO].                                                                                                                                            |  |
| 2<br>PAR   | Parity or ECC error  No local bus parity error  Local bus parity error (GPCM or UPM), ornon-correctable ECC error (FCM). LTEATR[PB] indicates the byte lane that caused the error and LTEATR[BNK] indicates which memory controller bank was accessed.                                                         |  |
| 3–4        | This field is reserved. Reserved                                                                                                                                                                                                                                                                               |  |
| 5<br>WP    | <ul> <li>Write protect error</li> <li>No write protect error occurred.</li> <li>A write was attempted to a local bus memory region that was defined as read-only in the memory controller. Usually, in this case, a bus monitor time-out will occur (as the cycle is not automatically terminated).</li> </ul> |  |
| 6–11       | This field is reserved. Reserved                                                                                                                                                                                                                                                                               |  |
| 12<br>CS   | Chip select error  O No chip select error occurred.  1 A transaction was sent to the eLBC that did not hit any memory bank.                                                                                                                                                                                    |  |
| 13–29<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                               |  |
| 30<br>UCC  | UPM Run pattern (MxMR[OP]=11) command completion event  0 No UPM Run pattern operation in progress, or operation pending.  1 UPM Run pattern operation has completed, allowing software to continue processing of results.                                                                                     |  |
| 31<br>CC   | FCM command completion event  O No FCM operation in progress, or operation pending.  1 FCM operation has completed, allowing software to continue processing of results.                                                                                                                                       |  |

# 12.3.17 Transfer error disable register (eLBC\_LTEDR)

The transfer error check disable register (LTEDR) is used to disable error/event checking, which are reported in LTESR. Note that control of error/event checking is independent of control of reporting of errors/events (LTEIR) through the interrupt mechanism.



eLBC\_LTEDR field descriptions

| Field     | Description                                                                                                                                                                                                 |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>BMD  | Bus monitor disable                                                                                                                                                                                         |  |  |  |
|           | 0 Bus monitor is enabled.                                                                                                                                                                                   |  |  |  |
|           | 1 Bus monitor is disabled, but internal bus time-outs can still occur.                                                                                                                                      |  |  |  |
| 1<br>FCTD | FCM command time-out disable                                                                                                                                                                                |  |  |  |
|           | 0 FCM command timer is enabled.                                                                                                                                                                             |  |  |  |
|           | 1 FCM command time-out is disabled, but internal FCM command timer can terminate command waits.                                                                                                             |  |  |  |
| 2<br>PARD | Parity and ECC error checking disabled. Note that non-correctable read errors may cause the assertion of core_fault_in, which causes the core to generate a machine check interrupt, unless it is disabled. |  |  |  |
|           | 0 Parity and ECC error checking is enabled.                                                                                                                                                                 |  |  |  |
|           | 1 Parity and ECC error checking is disabled.                                                                                                                                                                |  |  |  |
| 3–4       | This field is reserved.                                                                                                                                                                                     |  |  |  |
| -         | Reserved                                                                                                                                                                                                    |  |  |  |
| 5<br>WPD  | Write protect error checking disable.                                                                                                                                                                       |  |  |  |
|           | 0 Write protect error checking is enabled.                                                                                                                                                                  |  |  |  |
|           | 1 Write protect error checking is disabled.                                                                                                                                                                 |  |  |  |
| 6–11<br>- | This field is reserved. Reserved                                                                                                                                                                            |  |  |  |

## **eLBC\_LTEDR** field descriptions (continued)

| Field      | Description                                                |  |  |  |
|------------|------------------------------------------------------------|--|--|--|
| 12<br>CSD  | Chip select error checking disable.                        |  |  |  |
|            | 0 Chip select error checking is enabled.                   |  |  |  |
|            | 1 Chip select error checking is disabled.                  |  |  |  |
| 13–29<br>- | This field is reserved. Reserved                           |  |  |  |
| 30<br>UCCD | UPM Run pattern command completion checking disable.       |  |  |  |
|            | 0 UPM Run pattern command completion checking is enabled.  |  |  |  |
|            | 1 UPM Run pattern command completion checking is disabled. |  |  |  |
| 31<br>CCD  | FCM command completion checking disable.                   |  |  |  |
|            | 0 Command completion checking is enabled.                  |  |  |  |
|            | 1 Command completion checking is disabled.                 |  |  |  |

# 12.3.18 Transfer error interrupt register (eLBC\_LTEIR)

The transfer error interrupt enable register (LTEIR) is used to send or block error/event reporting through the eLBC internal interrupt mechanism. Software should clear pending errors/events in LTESR before enabling interrupts. After an interrupt has occurred, clearing relevant LTESR error/event bits negates the interrupt.

Address: 5000h base + B8h offset = 50B8h



#### eLBC\_LTEIR field descriptions

| Field    | Description                                         |  |  |
|----------|-----------------------------------------------------|--|--|
| 0<br>BMI | Bus monitor error interrupt enable.                 |  |  |
|          | 0 Bus monitor error reporting is disabled.          |  |  |
|          | Bus monitor error reporting is enabled.             |  |  |
| 1        | FCM command time-out interrupt enable.              |  |  |
| FCTI     |                                                     |  |  |
|          | 0 FCM command time-out error reporting is disabled. |  |  |
|          | 1 FCM command time-out error reporting is enabled.  |  |  |

## **eLBC\_LTEIR** field descriptions (continued)

| Field      | Description                                                                                                                                                                     |  |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2<br>PARI  | Parity and ECC error interrupt enable.  O Parity and ECC error reporting is disabled.  Parity and ECC error reporting is enabled.                                               |  |  |  |
| 3–4<br>-   | This field is reserved. Reserved                                                                                                                                                |  |  |  |
| 5<br>WPI   | Write protect error interrupt enable.  0 Write protect error reporting is disabled.  1 Write protect error reporting is enabled.                                                |  |  |  |
| 6–11<br>-  | This field is reserved. Reserved                                                                                                                                                |  |  |  |
| 12<br>CSI  | Chip select error interrupt enable.  Chip select error reporting is disabled.  Chip select error reporting is enabled.                                                          |  |  |  |
| 13–29<br>- | This field is reserved. Reserved                                                                                                                                                |  |  |  |
| 30<br>UCCI | UPM Run pattern command completion Event interrupt enable.  UPM Run pattern command completion reporting is disabled.  UPM Run pattern command completion reporting is enabled. |  |  |  |
| 31<br>CCI  | FCM command completion Event interrupt enable.  0 Command completion reporting is disabled.  1 Command completion reporting is enabled.                                         |  |  |  |

# 12.3.19 Transfer error attributes register (eLBC\_LTEATR)

The transfer error attributes register (LTEATR) captures source attributes of an error/ event. After LTEATR[V] has been set, software must clear this bit to allow LTESR, LTEATR, and LTEAR to update following any subsequent events/errors.

#### NOTE

LTEATR may not capture accurate information for errors that occur when an FCM special operation is in progress.

Address: 5000h base + BCh offset = 50BCh



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### eLBC\_LTEATR field descriptions

| Field                                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–2<br>-                                                                                     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 3<br>RWB                                                                                     | Transaction type for the error:  0 The transaction for the error was a write transaction.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                                                                                              | 1 The transaction for the error was a read transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 4–10<br>-                                                                                    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 11–15<br>SRCID                                                                               | Captures the source of the transaction when this information is provided on the internal interface to eLBC.                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 16–19<br>PB                                                                                  | Parity error on byte or block . For GPCM and UPM, there are four parity error status bits, one per byte lane. A bit is set for the byte that had a parity error (bit 16 represents byte 0, the most significant byte lane). For FCM, there are at most four 512-byte page blocks (for a large page device) checked by ECC. A bit is set for the 512-byte block that had an non-correctable ECC error on read (bit 16 represents block 0, the first 512 bytes of a page; if ORx[PGS] = 0, bits 17-19 are always 0). |  |  |
| 20–27<br>BNK                                                                                 | Memory controller bank. There is one error status bit per memory controller bank (bit 20 represents bank 0). A bit is set for the local bus memory controller bank that had an error.                                                                                                                                                                                                                                                                                                                              |  |  |
| 28–30<br>-                                                                                   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 31 Error attribute capture is valid. Indicates that the captured error information is valid. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|                                                                                              | <ul><li>0 Captured error attributes and address are not valid.</li><li>1 Captured error attributes and address are valid.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                |  |  |

# 12.3.20 Transfer error address register (eLBC\_LTEAR)

The transfer error address register (LTEAR) captures the address of a transaction that caused an error/event.

#### NOTE

LTEAR may not capture accurate information for errors that occur when an FCM special operation is in progress.

Address: 5000h base + C0h offset = 50C0h



## eLBC\_LTEAR field descriptions

| Field     | Description                                                                                                                                                  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–31<br>A | Transaction address for the error. For GPCM and UPM, holds the 32-bit address of the transaction resulting in an error. For FCM, this register is undefined. |  |

# 12.3.21 Transfer error ECC register (eLBC\_LTECCR)

The transfer error ECC register (LTECCR) captures single bit and multibit errors per 512-byte sector in FCM mode. LTECCR is a write-1-to-clear register. Write operations can clear but not set bits. It captures the errors during full page read transfers on FCM command completion event, provided ECC check is enabled in BRx[DECC].





## eLBC\_LTECCR field descriptions

| Field                                                                                                                                                                                                                                                                              | Description                                                                                                                                                                                                                                                                                                       |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–11<br>-                                                                                                                                                                                                                                                                          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                  |  |  |
| 12–15<br>SBCE                                                                                                                                                                                                                                                                      | Single bit correctable error. There are at most four 512-byte page blocks (for a large page device) checked by ECC. A bit is set for the 512-byte block that had a single bit correctable ECC error on read (bit 12 represents block 0, the first 512 bytes of a page; if ORx[PGS] = 0, bits 13-15 are always 0). |  |  |
| 16–27<br>-                                                                                                                                                                                                                                                                         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                  |  |  |
| Multi bit uncorrectable error There are at most four 512-byte page blocks (for a large page checked by ECC. A bit is set for the 512-byte block that had an uncorrectable ECC error or represents block 0, the first 512 bytes of a page; if ORx[PGS] = 0, bits 29-31 are always 0 |                                                                                                                                                                                                                                                                                                                   |  |  |

# 12.3.22 Configuration register (eLBC\_LBCR)





## eLBC\_LBCR field descriptions

| Field | Description                                                                                               |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------|--|--|--|
| 0     | Local bus disable                                                                                         |  |  |  |
| LDIS  |                                                                                                           |  |  |  |
|       | 0 Local bus is enabled.                                                                                   |  |  |  |
|       | 1 Local bus is disabled. No internal transactions will be acknowledged.                                   |  |  |  |
| 1–7   | This field is reserved.                                                                                   |  |  |  |
| -     | Reserved                                                                                                  |  |  |  |
| 8–9   | Defines the use of LBCTL                                                                                  |  |  |  |
| BCTLC |                                                                                                           |  |  |  |
|       | 00 LBCTL is used as W/ R control for GPCM or UPM accesses (buffer control).                               |  |  |  |
|       | 01 LBCTL is used as LOE for GPCM accesses only.                                                           |  |  |  |
|       | 10 LBCTL is used as TWE for GPCM accesses only.                                                           |  |  |  |
|       | 11 Reserved                                                                                               |  |  |  |
| 10    | Address hold disable. Removes part of the hold time for LAD with respect to LALE in order to lengthen the |  |  |  |
| AHD   | LALE pulse.                                                                                               |  |  |  |

# eLBC\_LBCR field descriptions (continued)

|             | 0 During address phases on the local bus, the LALE signal negates one platform clock period prior to                                                                                                                                                                 |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|             | the address being invalidated. For instance, at 333 MHz, this provides 3 ns of additional address hold time at the external address latch. Running the platform at a lower frequency improves the hold time.                                                         |  |  |  |
|             | 1 During address phases on the local bus, the LALE signal negates 0.5 platform clock period prior to the address being invalidated. This halves the address hold time, but extends the latch enable duration. This may be necessary for very high frequency designs. |  |  |  |
| 11<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                     |  |  |  |
| 12<br>ABSWP | Address byte swap for 16-bit port size. This address data muxing option saves pins on the device by swapping the LSB of address on the MSB of the LAD bus. It is mutually exclusive from AS16 field. If both ABSWP and AS16 are set, AS16 takes priority.            |  |  |  |
|             | O For all port sizes, the most significant bit of the memory address during LALE assertion appears on the LAD[0] data bus line, while less significant bits appear on lines to the right of this, with the least significant bit appearing on the LAD[15] line.      |  |  |  |
|             | 1 LAD[0:7] MSB now muxes the least significant byte of address [24:31] and LAD[8:15] muxes the next<br>least significant byte of address [16:23].                                                                                                                    |  |  |  |
| 13<br>AS16  | Address shift for 16-bit port size.                                                                                                                                                                                                                                  |  |  |  |
|             | For both port sizes the most-significant bit of the memory address during LALE assertion appears on<br>the LAD[0] signal, while less-significant bits appear on subsequent signals, with the least-significant b<br>appearing on line LAD[15].                       |  |  |  |
|             | 1 For 16-bit port sizes, the least-significant address bits (1:10) are driven on LA[22:31], rest 16 bits of the valid 26-bit memory address are driven on LAD[0:15].                                                                                                 |  |  |  |
| 14<br>LPBSE | Enables parity byte select on LGTA/LFRB /LGPL4/LUPWAIT/LPBSE signal.                                                                                                                                                                                                 |  |  |  |
|             | O Parity byte select is disabled. LGTA/ LGPL4/LPBSE signal is available for memory control as LGPL4 (output) or LGTA/LFRB /LUPWAIT (input).                                                                                                                          |  |  |  |
|             | Parity byte select is enabled. LPBSE signal is dedicated as the parity byte select output, and LGTA/LFRB /LUPWAIT is disabled.                                                                                                                                       |  |  |  |
| 15<br>EPAR  | Determines odd or even parity. Writing GPCM or UPM controlled memory with EPAR = 1 and reading the memory with EPAR = 0 generates parity errors for testing.                                                                                                         |  |  |  |
|             | <ul><li>Odd parity; normal, odd-parity ECC</li><li>Even parity; inverted, even-parity ECC</li></ul>                                                                                                                                                                  |  |  |  |
|             | Bus monitor timing. Defines the bus monitor time-out period. The number of LCLK clock cycles to count                                                                                                                                                                |  |  |  |
|             | down before a time-out error is generated is given by: if BMT = 0, then bus cycles = 256 x PS                                                                                                                                                                        |  |  |  |
|             | if BMT ≠ 0, then bus cycles = BMT x PS                                                                                                                                                                                                                               |  |  |  |
|             | where PS is set according to LBCR[BMTPS].                                                                                                                                                                                                                            |  |  |  |
|             | The value of bus cycles must not be less than 40 bus cycles for reliable operation. When BMT = $0$ , bus cycles = $256 \times PS$ .                                                                                                                                  |  |  |  |
| 24–27<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                     |  |  |  |
| BMTPS       | Bus monitor timer prescale. Defines the multiplier, PS, to scale LBCR[BMT] for determining bus time-outs                                                                                                                                                             |  |  |  |
|             | 0000 PS = 8                                                                                                                                                                                                                                                          |  |  |  |
|             | 0001 PS = 16<br>0010 PS = 32                                                                                                                                                                                                                                         |  |  |  |

## **eLBC\_LBCR** field descriptions (continued)

| Field | Description      |  |  |
|-------|------------------|--|--|
| 00    | 011 PS = 64      |  |  |
| 01    | 100 PS = 128     |  |  |
| 01    | 101 PS = 256     |  |  |
| 01    | 110 PS = 512     |  |  |
| 01    | 111 PS = 1024    |  |  |
| 10    | 000 PS = 2048    |  |  |
| 10    | 001 PS = 4096    |  |  |
| 10    | 010 PS = 8192    |  |  |
| 10    | 011 PS = 16,384  |  |  |
|       | 100 PS = 32,768  |  |  |
|       | 101 PS = 65,536  |  |  |
|       | 110 PS = 131,072 |  |  |
| 11    | 111 PS = 262,144 |  |  |

# 12.3.23 Clock ratio register (eLBC\_LCRR)

The clock ratio register sets the platform clock to eLBC bus frequency ratio. It also provides configuration bits for extra delay cycles for address and control signals.

### NOTE

For proper operation of the system, it is required that this register setting will not be altered while local bus memories or devices are being accessed. Special care needs to be taken when running instructions from an eLBC memory.

Address: 5000h base + D4h offset = 50D4h



## eLBC\_LCRR field descriptions

| Field         | Description                                                                                          |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------|--|--|--|
| 0–13<br>-     | This field is reserved. Reserved.                                                                    |  |  |  |
| 14–15<br>EADC | External address delay cycles of LCLK. Defines the number of cycles for the assertion of LALE.  00 4 |  |  |  |
|               | 01 1                                                                                                 |  |  |  |

## eLBC\_LCRR field descriptions (continued)

| Field                                                                                                                                                |                                                                                                                                                                                                                                                                                                                       | Description                          |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|
|                                                                                                                                                      | 10 2                                                                                                                                                                                                                                                                                                                  |                                      |  |
|                                                                                                                                                      | 11 3                                                                                                                                                                                                                                                                                                                  |                                      |  |
| 16–26<br>-                                                                                                                                           | This field is res<br>Reserved                                                                                                                                                                                                                                                                                         | This field is reserved. Reserved     |  |
| 27–31<br>CLKDIV                                                                                                                                      | Clock divider. Sets the frequency ratio between the platform clock and the local bus clock. Only the values shown below are allowed.                                                                                                                                                                                  |                                      |  |
|                                                                                                                                                      | NOTE: It is critical that no transactions are being executed via the local bus while CLKDIV is being modified. As such, prior to modification, the user must ensure that code is not executing out of the local bus. Once LCRR[CLKDIV] is written, the register should be read, and then an isync should be executed. |                                      |  |
|                                                                                                                                                      | 00000-00001                                                                                                                                                                                                                                                                                                           | Reserved                             |  |
| 00010 4 00011 Reserved 00100 8(default for boot ROM set to FCM) 00101-00111 Reserved 01000 16(default for boot ROM set to GPCM) 01001-11111 Reserved |                                                                                                                                                                                                                                                                                                                       | 4                                    |  |
|                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                       | Reserved                             |  |
|                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                       | 8(default for boot ROM set to FCM)   |  |
|                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                       | Reserved                             |  |
|                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                       | 16(default for boot ROM set to GPCM) |  |
|                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                       | Reserved                             |  |

# 12.3.24 Flash mode register (eLBC\_FMR)

The local bus Flash mode register (FMR) controls global operation of the FCM.

Address: 5000h base + E0h offset = 50E0h



<sup>\*</sup> Notes:

• BOOT field: Bit is set if power-on-reset configuration selects FCM as the boot ROM target.

#### **Enhanced Local Bus Controller (eLBC) Memory Map**

## eLBC\_FMR field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16–19<br>CWTO | Command wait time-out. For FCM commands that wait on LFRB being sampled high (CW0, CW1, RBW, and RSW), FCM pauses execution of the instruction sequence until either LFRB is sampled high, or a timer controlled by CTO expires, whichever occurs first. The time-out in the latter case is as follows:                                                                                                                                              |
|               | 0000 256 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | 0001 512 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | 0010 1024 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 0011 2048 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 0100 4096 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 0101 8192 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 0110 16,384 cycles of LCLK<br>0111 32.768 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 0111 32,768 cycles of LCLK<br>1000 65,536 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 1001 131,072 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | 1010 262,144 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | 1011 524,288 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | 1100 1,048,576 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 1101 2,097,152 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 1110 4,194,304 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 1111 8,388,608 cycles of LCLK                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 20<br>BOOT    | Flash auto-boot load mode. During system boot from NAND Flash EEPROM, this bit remains set to alter the use of the FCM buffer RAM. Software should clear BOOT once FCM is to be restored to normal operation. Setting BOOT without auto-boot in progress only alters the mapping of the buffer RAM.                                                                                                                                                  |
|               | 0 FCM is operating in normal functional mode, with an 8 Kbyte FCM buffer RAM.                                                                                                                                                                                                                                                                                                                                                                        |
|               | 1 eLBC has been configured-either from reset or by a special operation OP = 01-to autoload a 4-Kbyte boot block into the FCM buffer RAM, which maps only the 4 Kbytes of NAND Flash main data region comprising the boot block. Any access to the buffer RAM is delayed until the entire boot block has been loaded.                                                                                                                                 |
| 21–22         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23<br>ECCM    | ECC mode. When hardware checking and/or generation of error correcting codes (ECC) is enabled (that is, when BRn[DECC] is 01 or 10, and full page transfers are specified with FBCR[BC] = 0), ECCM sets the ECC block size and position of the ECC code word(s) in the NAND Flash spare region for both checking and generation functions. The format of the ECC code word conforms with the Samsung/Toshiba spare region assignment specifications. |
|               | 0 ECC is checked/calculated over 512-Byte blocks. A 24-bit ECC is assigned to spare region bytes at offsets (N x 16) + 6 through (N x 16) + 8 for spare region N, N = 0-3.                                                                                                                                                                                                                                                                           |
|               | 1 ECC is checked/calculated over 512-Byte blocks. A 24-bit ECC is assigned to spare region bytes at offsets (N x 16) + 8 through (N x 16) + 10 for spare region N, N = 0-3.                                                                                                                                                                                                                                                                          |
| 24–25         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 26–27<br>AL   | Address length. AL sets the number of address bytes issued during page address (PA) operations. However, the number of address bytes issued for column address (CA) operations is determined by the device page size (for ORn[PGS] = 0, 1 CA byte is issued; for ORn[PGS] = 1, 2 CA bytes are issued).                                                                                                                                               |

#### **eLBC\_FMR** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
|             | <ul> <li>2 bytes are issued for page addresses, thus a total of 3 (ORn[PGS] = 0) or 4 (ORn[PGS] = 1) address bytes are issued for a {CA,PA} sequence</li> <li>3 bytes are issued for page addresses, thus a total of 4 (ORn[PGS] = 0) or 5 (ORn[PGS] = 1)</li> </ul>                                                   |  |  |  |  |  |  |  |  |  |  |
|             | <ul> <li>address bytes are issued for a {CA,PA} sequence</li> <li>4 bytes are issued for page addresses, thus a total of 5 (ORn[PGS] = 0) or 6 (ORn[PGS] = 1) address bytes are issued for a {CA,PA} sequence</li> <li>Reserved</li> </ul>                                                                             |  |  |  |  |  |  |  |  |  |  |
| 28–29       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |
| 30–31<br>OP | Flash operation. For OP not equal to 00, a special operation is triggered on the next write to LSOR or dummy access to a bank controlled by FCM. Once a special operation has commenced, OP is automatically reset to 00 by FCM. Individual blocks may be temporarily unlocked for erase and reprogramming operations. |  |  |  |  |  |  |  |  |  |  |
|             | 00 Normal operation. All read and write accesses to banks controlled by FCM access the shared FCM buffer RAM. No bus activity is caused by this operation.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |
|             | O1 Simulate auto-boot block loading, and set FMR[BOOT]. Boot block loading occurs from the bank triggered on the special operation, therefore the appropriate bank configuration must be initialized prior to issuing this operation.                                                                                  |  |  |  |  |  |  |  |  |  |  |
|             | 10 Execute the command sequence contained in FIR, but with write protection enabled (pin LFWP asserted low) so that all Flash blocks are protected from accidental erasure and reprogramming.                                                                                                                          |  |  |  |  |  |  |  |  |  |  |
|             | 11 Execute the command sequence contained in FIR, but permit the single block identified by FBAR[BLK] to be erased or reprogrammed, with pin LFWP remaining high during the access.                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |

# 12.3.25 Flash instruction register (eLBC\_FIR)

The local bus Flash instruction register (FIR) holds a sequence of up to eight instructions for issue by the FCM. Setting FMR[OP] non-zero and writing LSOR or accessing a bank controlled by FCM causes FCM to read FIR 4 bits at a time, starting at bit 0 and continuing with adjacent 4-bit opcodes, until only NOP opcodes remain. The programmed instruction sequence of OP0, OP1,..., OP7 is performed on the activated bank, using the data buffer addressed by FPAR. If LTEIR[CCI] = 1 and LTEDR[CCD] = 0, eLBC will generate an interrupt once the entire sequence has completed, and software should examine LTEATR and clear its V bit.

Software must not alter the contents of the addressed FCM buffer, FIR, MDR, FCR, FBAR, FPAR, or FBCR while an operation is in progress-or eLBC will behave unpredictably-but software can freely modify the contents of any currently unused FCM RAM buffer in preparation for the next operation.

Address: 5000h base + E4h offset = 50E4h

| Bit    | 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 |
|--------|---|----|----|---|---|----|----|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R<br>W |   | OI | 90 |   |   | OI | 21 |   |   | OI | 2  |    |    | Ol | P3 |    |    | OF | P4 |    |    | Ol | 25 |    |    | Ol | P6 |    |    | Ol | 27 |    |
| Reset  | 0 | 0  | 0  | 0 | 0 | 0  | 0  | 0 | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## Enhanced Local Bus Controller (eLBC) Memory Map

# eLBC\_FIR field descriptions

| Field        | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0–3<br>OP0   | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7.                                                        |
| 0.0          | 0000 NOP-No-operation and end of operation sequence                                                                                 |
|              | 0001 CA-Issue current column address as set in FPAR, with length set by ORx[PGS]                                                    |
|              | 0010 PA-Issue current block+page address as set in FBAR and FPAR, with length set by FMR[AL]                                        |
|              | 0011 UA-Issue user-defined address byte from next AS field in MDR                                                                   |
|              | 0100 CM0-Issue command from FCR[CMD0]                                                                                               |
|              | 0101 CM1-Issue command from FCR[CMD1]                                                                                               |
|              | 0110 CM2-Issue command from FCR[CMD2]                                                                                               |
|              | 0111 CM3-Issue command from FCR[CMD3]                                                                                               |
|              | 1000 WB-Write FBCR bytes of data from current FCM buffer to Flash device                                                            |
|              | 1001 WS-Write one byte (8b port) of data from next AS field of MDR to Flash device                                                  |
|              | 1010 RB-Read FBCR bytes of data from Flash device into current FCM RAM buffer                                                       |
|              | 1011 RS-Read one byte (8b port) of data from Flash device into next AS field of MDR                                                 |
|              | 1100 CW0-Wait for LFRB to return high or time-out, then issue command from FCR[CMD0]                                                |
|              | 1101 CW1-Wait for LFRB to return high or time-out, then issue command from FCR[CMD1]                                                |
|              | 1110 RBW-Wait for LFRB to return high or time-out, then read FBCR bytes of data from Flash device into current FCM RAM buffer       |
|              | 1111 RSW-Wait for LFRB to return high or time-out, then read one byte (8b port) of data from Flash device into next AS field of MDR |
| 4–7<br>OP1   | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 8–11<br>OP2  | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 12–15<br>OP3 | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 16–19<br>OP4 | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 20–23<br>OP5 | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 24–27<br>OP6 | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |
| 28–31<br>OP7 | FCM operation codes. OP0 is executed first, followed by OP1, through to OP7. See description for OP0.                               |

# 12.3.26 Flash command register (eLBC\_FCR)

The local bus Flash command register (FCR) holds up to four NAND Flash EEPROM command bytes that may be referenced by opcodes in FIR during FCM operation. The values of the commands should follow the manufacturer's datasheet for the relevant NAND Flash device.



| Bit   | 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 |
|-------|---|---|---|----|-----|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|-----|----|----|----|
| R     |   |   |   | CM | ID0 |   |   |   |   |   |    | CM | ID1 |    |    |    |    |    |    | СМ | ID2 |    |    |    |    |    |    | CIV | ID3 |    |    |    |
| W     |   |   |   |    |     |   |   |   |   | _ |    | _  |     | _  |    | _  | _  |    |    |    |     |    |    |    |    |    |    | _   |     |    |    |    |
| Reset | 0 | 0 | 0 | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

### **eLBC\_FCR** field descriptions

| Field         | Description                                                                                                                        |
|---------------|------------------------------------------------------------------------------------------------------------------------------------|
| 0-7<br>CMD0   | General purpose FCM Flash command byte 0. Opcodes in FIR that issue command index 0 write CMD0 to the NAND Flash command/data bus. |
| 8–15<br>CMD1  | General purpose FCM Flash command byte 1. Opcodes in FIR that issue command index 1 write CMD1 to the NAND Flash command/data bus. |
| 16–23<br>CMD2 | General purpose FCM Flash command byte 2. Opcodes in FIR that issue command index 2 write CMD2 to the NAND Flash command/data bus. |
| 24-31<br>CMD3 | General purpose FCM Flash command byte 3. Opcodes in FIR that issue command index 3 write CMD3 to the NAND Flash command/data bus. |

# 12.3.27 Flash block address register (eLBC\_FBAR)

The local bus Flash block address register (FBAR) locates the NAND Flash block index for the page currently accessed.

Address: 5000h base + ECh offset = 50ECh



#### eLBC\_FBAR field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–7   | This field is reserved. |
| -     | Reserved                |

#### **Enhanced Local Bus Controller (eLBC) Memory Map**

## eLBC\_FBAR field descriptions (continued)

| Field | Description                                                                                                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Flash block address. The size of the NAND Flash, as configured in ORn[PGS] and FMR[AL], determines the number of bits of BLK that are issued to the EEPROM during block address phases. |

# 12.3.28 Flash page address register [Large Page Device (ORx[PGS] = 1)] (eLBC\_FPARI)

The local bus Flash page address register (FPAR) locates the current NAND Flash page in both the external NAND Flash device and FCM buffer RAM.

Address: 5000h base + F0h offset = 50F0h



#### eLBC\_FPARI field descriptions

| Field       | Description                                                                                                                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–13<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                |
| 14–19<br>PI | Page index. PA indexes the page in NAND Flash EEPROM at the current block defined by FBAR, and locates the corresponding transfer buffer in the FCM buffer RAM.                                                                                                                 |
|             | The LSB of PI indexes one of the two 4 Kbyte buffers in the FCM buffer RAM as follows:                                                                                                                                                                                          |
|             | 0 The page is transferred to/from FCM buffer 0, address offsets 0x0000-0x0FFF                                                                                                                                                                                                   |
|             | 1 The page is transferred to/from FCM buffer 1, address offsets 0x1000-0x1FFF                                                                                                                                                                                                   |
| 20<br>MS    | Main/spare region locator. In the case that FBCR[BC] = 0, MS is treated as 0.                                                                                                                                                                                                   |
|             | O Data is transferred to/from the main region of the FCM buffer; that is, the first 2048 bytes of the buffer are used as the starting address.                                                                                                                                  |
|             | 1 Data is transferred to/from the spare region of the FCM buffer; that is, the second 2048 bytes of the buffer are used as the starting address, but only an initial 64 bytes of spare region are defined.                                                                      |
| 21–31<br>Cl | Column index. CI indexes the first byte to transfer to/from the main or spare region of the NAND Flash EEPROM and corresponding transfer buffer. In the case that FBCR[BC] = 0, CI is treated as 0. For MS = 0, CI can range 0x000-0x7FF; for MS = 1, CI can range 0x000-0x03F. |

# 12.3.29 Flash page address register [Small Page Device (ORx[PGS] = 0)] (eLBC\_FPARs)

The local bus Flash page address register (FPAR) locates the current NAND Flash page in both the external NAND Flash device and FCM buffer RAM.

Address: 5000h base + F0h offset = 50F0h



## **eLBC\_FPARs** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 0–16<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |
| 17–21<br>PI | Page index. PI indexes the page in NAND Flash EEPROM at the current block defined by FBAR, and locates the corresponding transfer buffer in the FCM buffer RAM.                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | The 3 LSBs of PI index one of the eight 1 Kbyte buffers in the FCM buffer RAM as follows:                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |
|             | 000 The page is transferred to/from FCM buffer 0, address offsets 0x0000-0x03FF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 001 The page is transferred to/from FCM buffer 1, address offsets 0x0400-0x07FF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 010 The page is transferred to/from FCM buffer 2, address offsets 0x0800-0x0BFF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 011 The page is transferred to/from FCM buffer 3, address offsets 0x0C00-0x0FFF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 100 The page is transferred to/from FCM buffer 4, address offsets 0x1000-0x13FF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 101 The page is transferred to/from FCM buffer 5, address offsets 0x1400-0x17FF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 110 The page is transferred to/from FCM buffer 6, address offsets 0x1800-0x1BFF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
|             | 111 The page is transferred to/from FCM buffer 7, address offsets 0x1C00-0x1FFF                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
| 22<br>MS    | Main/spare region locator. In the case that FBCR[BC] = 0, MS is treated as 0.                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |
|             | O Data is transferred to/from the main region of the FCM buffer; that is, the first 512 bytes of the buffer are used as the starting address.                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |
|             | 1 Data is transferred to/from the spare region of the FCM buffer; that is, the second 512 bytes of the buffer are used as the starting address, but only an initial 16 bytes of spare region are defined.                                                                       |  |  |  |  |  |  |  |  |  |  |
| 23–31<br>Cl | Column index. CI indexes the first byte to transfer to/from the main or spare region of the NAND Flash EEPROM and corresponding transfer buffer. In the case that FBCR[BC] = 0, CI is treated as 0. For MS = 0, CI can range 0x000-0x1FF; for MS = 1, CI can range 0x000-0x00F. |  |  |  |  |  |  |  |  |  |  |

# 12.3.30 Flash byte count register (eLBC\_FBCR)

The local bus Flash byte count register (FBCR) defines the size of FCM block transfers for reads and writes to the NAND Flash EEPROM.

Address: 5000h base + F4h offset = 50F4h



### eLBC\_FBCR field descriptions

| Field       | Description                                                                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                       |
| 20–31<br>BC | Byte count determines how many bytes are transferred by the FCM during data read (RB) or data write (WB) opcodes.                                                                                                                                      |
|             | The first byte accessed in the NAND Flash EEPROM is located by the FPAR register, and successive bytes are transferred until either BC bytes have been counted, or the end of the spare region of the currently addressed Flash page has been reached. |
|             | If BC = 0, an entire Flash page and its spare region will be transferred by FCM, in which case FPAR[MS] and FPAR[CI] are treated as zero regardless of their values. BC = 0 is the only setting that permits FCM to generate and check ECC.            |

# 12.3.31 Flash ECC block n registers (eLBC\_FECCn)

The local bus Flash ECC block n register (FECC n) specifies the ECC value calculated during writes or reads by eLBC. It can be used for verify after write feature in software. Note that the valid bit sets before the command completion event and hence the correct ECC could be read before actual completion of writes/reads.



eLBC\_FECCn field descriptions

| Field       | Description                                                                                                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>V      | Valid bit. This bit denotes that the ECC stored in this register is valid. It is set for full page write/read transfers if ECC generation/checking is enabled in BRn[DECC].                                 |
| 1–7         | This field is reserved. Reserved                                                                                                                                                                            |
| 8–31<br>ECC | 24 bit ECC; For n <sup>th</sup> 512 bytes of a page in case of large page or for (4k + n) <sup>th</sup> 512 byte page for small page where k = 0,1,2,). It stores calculated ECC value during writes/reads. |

# 12.4 eLBC functional description

The eLBC allows the implementation of memory systems with very specific timing requirements.

- The GPCM provides interfacing for simpler, lower-performance memories and memory-mapped devices. It has inherently lower performance because it does not support bursting. For this reason, GPCM-controlled banks are used primarily for boot-loading from NVRAM or NOR Flash, and access to low-performance memory-mapped peripherals.
- The FCM interfaces the eLBC to NAND Flash EEPROMs with 8-bit data bus. The FCM has an automatic boot-loading feature that allows the CPU to boot from high

density EEPROM, loading the boot block into 4 Kbytes of RAM for execution of the first level boot code. Following boot, FCM provides a flexible instruction sequencer that allows a user-defined command, address, and data transfer sequence of up to 8 steps to be executed against a memory-mapped buffer RAM. Programmable set-up time, hold time, and wait states permit the FCM to maximize the performance of NAND Flash block transfers, which can proceed in parallel with software processing of the multiple RAM buffers. A single-pass ECC engine in the FCM permits zero-overhead error checking, reporting, and correction in both boot blocks and page data transfers if enabled.

• The UPM supports refresh timers, address multiplexing of the external bus, and generation of programmable control signals for row address and column address strobes, to allow for a minimal glue logic interface to DRAMs, burstable SRAMs, and almost any other kind of peripheral with asynchronous timing or single data rate clocking. The UPM can be used to generate flexible, user-defined timing patterns for control signals that govern a memory device. These patterns define how the external control signals behave during a read, write, burst-read, or burst-write access. Refresh timers are also available to periodically initiate user-defined refresh patterns.



Figure 12-68. Basic operation of memory controllers in the eLBC

Each memory bank (chip select) can be assigned to any of these three types of machines through the machine select bits of the base register for that bank (BRn[MSEL]), as illustrated in the above figure. If a bank match occurs, the corresponding machine (GPCM, FCM, or UPM) then takes ownership of the external signals that control the access and maintains control until the transaction ends.

#### **NOTE**

Different machines (FCM/GPCM/UPM) share the address, data, and control signals. While the eLBC is servicing a transaction, subsequent transactions are queued until the current transaction has completed.

#### 12.4.1 Basic architecture

The following subsections describe the basic architecture of the eLBC.

## 12.4.1.1 Address and address space checking

The defined base addresses are written to the BRn registers, while the corresponding address masks are written to the ORn registers.

Each time a local bus access is requested, the internal transaction address is compared with each bank. Addresses are decoded by comparing the 17 MSBs of the address, masked by ORn[AM], with the base address for each bank (BRn[BA]). If a match is found on a memory controller bank, the attributes defined in the BRn and ORn for that bank are used to control the memory access. If a match is found in more than one bank, the lowest-numbered bank handles the memory access (that is, bank 0 has priority over bank 1).

# 12.4.1.2 External address latch enable signal (LALE)

The local bus uses a multiplexed address/data bus.

Therefore the eLBC must distinguish between address and data phases, which take place on the same bus (LAD pins). The LALE signal, when asserted, signifies an address phase during which the eLBC drives the memory address on the LAD pins. An external address latch uses this signal to capture the address and provide it to the address pins of the memory or peripheral device. When LALE is negated, LAD then serves as the (bi-directional) data bus for the access. Any address phase initiates the assertion of LALE, which has a programmable duration of between 1 and 4 bus clock cycles.

#### eLBC functional description

To ensure adequate hold time on the external address latch, LALE negates earlier than the address changes on LAD during address phases. By default, LALE negates earlier by 1 platform clock period. For example, if the platform clock is operating at 267 MHz, then 3.7 ns of address hold time is introduced. However, at higher frequencies, the duration of the shortened LALE pulse may not meet the minimum latch enable pulse width specifications of some latches. In such cases, setting LBCR[AHD] = 1 increases the LALE pulse width by ½ platform clock cycle, but decreases the address hold time by the same amount. If both longer hold time and longer LALE pulse duration are needed, then the address phase can be extended using the ORn[EAD] and LCRR[EADC] fields, and the LBCR[AHD] bit can be left at 0. However, this will add latency to all address tenures.

The frequency of LALE assertion varies across the three memory controllers:

- For GPCM, every assertion of LCSn\_B is considered an independent access, and accordingly, LALE asserts prior to each such access. For example, GPCM driving an 8-bit port would assert LALE and LCSn\_B 32 times in order to satisfy a 32-byte cache line transfer.
- For FCM, LALE asserts prior to each multi-command operation sequence, but LALE can be ignored on NAND Flash EEPROM accesses as the signal does *not* enable address latching in such devices. The value on the LAD and LA pins during LALE assertion is driven low-impedance, but otherwise not defined for FCM banks.
- In the case of UPM, the frequency of LALE assertion depends on how the UPM RAM is programmed. UPM single accesses typically assert LALE once, upon commencement, but it is possible to program UPM to assert LALE several times, and to change the values of LAn with and without LALE being involved.

In general, when using the GPCM controller it is typically required to use both LA and the latched version of LAD to capture the entire address during LALE phases. The UPMs may require LA if the eLBC is generating its own burst address sequence.

To illustrate how a large transaction is handled by the eLBC, the following figure shows eLBC signals for the GPCM performing a 32-byte write starting at address 0x1234\_5420. Note that during each of the 32 assertions of LALE, LA[16:31] and LAD[0:15] together drive the address, but during data phases, only LAD[0:7] and LDP[0] are driven with valid data and parity, respectively.



Figure 12-69. Example of 8-bit GPCM writing 32 bytes to address 0x1234\_5420

## 12.4.1.3 Data transfer acknowledge (TA)

The three memory controllers in the eLBC generate an internal transfer acknowledge signal, TA, to allow data on LAD to be either sampled (for reads) or changed (on writes).

The data sampling/data change always occurs at the end of the bus cycle in which the eLBC asserts TA internally. In eLBC debug mode, TA is also visible externally on the MDVAL pin. The GPCM controller automatically generates TA according to the timing parameters programmed for them in the option and mode registers; FCM generates TA whenever data read and write instructions are executed out of register FIR; a UPM generates TA only when a UPM pattern has the UTA RAM word bit set. Figure 12-70 shows LALE, TA (internal), and LCSn\_B . Note that TA and LALE are never asserted together, and that for the duration of LALE, LCSn\_B (or any other control signal) remains negated or frozen.



Figure 12-70. Basic eLBC bus cycle with LALE, TA, and LCSn\_B (PLL bypass)

## 12.4.1.4 Data buffer control (LBCTL)

The memory controller provides a data buffer control signal for the local bus (LBCTL).

This signal is activated when a GPCM-, FCM-, or UPM-controlled bank is accessed. LBCTL can be disabled by setting OR*n*[BCTLD]. LBCTL can be further configured by LBCR[BCTLC] to act as an extra LWE\_B or an extra LOE\_B signal when in GPCM mode.

If LBCTL is configured as a data buffer control (LBCR[BCTLC] = 00), the signal is asserted (high) on the rising edge of the bus clock on the first cycle of the memory controller operation, coincident with LALE. If the access is a write, LBCTL remains high for the whole duration. However, if the access is a read, LBCTL is negated (low) with the negation of LALE so that the memory device is able to drive the bus. If back-to-back

read accesses are pending, LBCTL is asserted (high) one bus clock cycle before the next transaction starts (that is, one bus clock cycle before LALE) to allow a whole bus cycle for the bus to turn around before the next address is driven.

# 12.4.1.5 Parity generation and checking (LDP)

Parity can be configured for any GPCM or UPM bank by programming BRn[DECC]. Parity is generated and checked on a per-byte basis using LDP[0:1] for the bank if BRn[DECC] = 01 (normal parity). Byte lane parity on LDP[0:1] is generated regardless of the BRn[DECC] setting.

FCM calculates an ECC over 512-byte blocks, and hence does not use the LDP[0:1] pins. The setting of BRn[DECC] = 01 enables ECC checking only, while BRn[DECC] = 10 enables ECC generation and checking; in either case, LBCR[EPAR] determines the global type of block parity for ECC (odd or even).

### 12.4.1.6 Bus monitor

A bus monitor is provided to ensure that each transaction is terminated within a reasonable (user defined) period.

When a transaction starts, the bus monitor starts counting down from the time-out value (LBCR[BMT] x LBCR[BMTPS]) until a data beat is acknowledged on the bus. It then reloads the time-out value and resumes the countdown until the data tenure completes and then idles if there is no pending transaction. Setting LTEDR[BMD] disables bus monitor error checking (that is, the LTESR[BM] bit is not set by a bus monitor time-out); however, the bus monitor is still active and can generate a UPM exception (as noted in Exception requests,) or terminate a GPCM access.

It is very important to ensure that the value of LBCR[BMT] is not set too low; otherwise spurious bus time-outs may occur during normal operation-resulting in incomplete data transfers. Accordingly, the time-out value represented by the LBCR[BMT], LBCR[BMTPS] pair must not be set below 40 bus cycles for time-out under any circumstances.

#### NOTE

When the FCM is in the middle of a long transaction (such as NAND erase, write, and so on), another transaction on the GPCM or UPM will trigger the bus monitor to start, even though the GPCM or UPM is waiting for the FCM to finish. If the bus monitor times out, it could corrupt the current NAND

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### eLBC functional description

Flash operation as well as terminate the GPCM or UPM operation. To avoid such cases, it is recommended that while using FCM the bus monitor timeout be programmed to its maximum setting of LBCR[BMT] = 0 and LBCR[BMTPS] = 0xF.

# 12.4.1.7 PLL Bypass mode

In PLL bypass mode, eLBC drives new address, data, and control signals effectively on falling edges of LCLK, but continues to sample synchronous read data on rising edges of LCLK to maximize the set-up margin for reads.

#### NOTE

Because LCLK is not used for NAND Flash EEPROMs controlled by FCM, the eLBC drives and samples data on the falling edge on FCM controlled banks.



Figure 12-71. eLBC bus cycles in PLL-bypassed mode (GPCM and UPM only)

# 12.4.2 General-purpose chip-select machine (GPCM)

The GPCM allows a minimal glue logic and flexible interface to SRAM, EPROM, FEPROM, ROM devices, and external peripherals.

The GPCM contains two basic configuration register groups-BRn and ORn.

Byte-write enable signals (LWE\_B) are available for each byte written to memory. Also, the output enable signal (LOE\_B) is provided to minimize external glue logic. On system reset, a global (boot) chip-select is available that provides a boot ROM chip-select (LCS0\_B) prior to the system being fully configured.



Figure 12-72. Enhanced local bus to GPCM device interface

The figure below shows LCS\_B as defined by the setup time required between the address lines and CE\_B. The user can configure ORn[ACS] to specify LCS\_B to meet this requirement. Generally, the attributes for the memory cycle are taken from ORn. These attributes include the CSNT, ACS, XACS, SCY, TRLX, EHTR, and SETA fields.



Figure 12-73. GPCM basic read timing (XACS = 0, ACS = 1x, TRLX = 0)

# 12.4.2.1 GPCM read signal timing

The basic GPCM read timing parameters that may be set by the ORn attributes are shown below.

The read access cycle commences upon latching of the memory address (LALE negated), and concludes when LBCTL returns high to turn the local bus around for a subsequent address phase. Read data is captured on the rising edge of LCLK when TA is asserted. LOE\_B and LCSn\_B negate high simultaneously, in some cases before the end of the read access to provide additional hold time for the external memory.



Figure 12-74. GPCM general read timing parameters with PLL bypass

The table below lists the signal timing parameters for a GPCM read access as the option register attributes are varied.

**Option Register Attributes** Signal Timing (LCLK clock cycles) **TRLX EHTR XACS ACS t**CSRP **t**ARCS t<sub>AOE</sub> t<sub>OEN</sub> t<sub>RC</sub> 0X 0 0 0 2 + SCY 0 2 + SCY 0 0 0 10 1/4 134 + SCY 0 2 + SCY 0 0 0 11 1/2 11/2 + SCY 0 2 + SCY 0 0 1 0X 0 2 + SCY 0 2 + SCY 0 10 0 1 + SCY 0 2 + SCY

Table 12-190. GPCM read control signal timing

Table 12-190. GPCM read control signal timing (continued)

| Option Register Attributes |      |      |     | Signal Timing (LCLK clock cycles) |                   |                  |                  |                 |  |
|----------------------------|------|------|-----|-----------------------------------|-------------------|------------------|------------------|-----------------|--|
| TRLX                       | EHTR | XACS | ACS | t <sub>ARCS</sub>                 | t <sub>CSRP</sub> | t <sub>AOE</sub> | t <sub>OEN</sub> | t <sub>RC</sub> |  |
| 0                          | 0    | 1    | 11  | 2                                 | 1 + SCY           | 2                | 0                | 3 + SCY         |  |
| 0                          | 1    | 0    | 0X  | 0                                 | 2 + SCY           | 1                | 1                | 3 + SCY         |  |
| 0                          | 1    | 0    | 10  | 1/4                               | 13/4 + SCY        | 1                | 1                | 3 + SCY         |  |
| 0                          | 1    | 0    | 11  | 1/2                               | 1½ + SCY          | 1                | 1                | 3 + SCY         |  |
| 0                          | 1    | 1    | 0X  | 0                                 | 2 + SCY           | 1                | 1                | 3 + SCY         |  |
| 0                          | 1    | 1    | 10  | 1                                 | 1 + SCY           | 1                | 1                | 3 + SCY         |  |
| 0                          | 1    | 1    | 11  | 2                                 | 1 + SCY           | 2                | 1                | 4 + SCY         |  |
| 1                          | 0    | 0    | 0X  | 0                                 | 2 + 2 x SCY       | 1                | 4                | 6 + 2 x SCY     |  |
| 1                          | 0    | 0    | 10  | 11/4                              | 134 + 2 x SCY     | 2                | 4                | 7 + 2 x SCY     |  |
| 1                          | 0    | 0    | 11  | 1½                                | 1½ + 2 x SCY      | 2                | 4                | 7 + 2 x SCY     |  |
| 1                          | 0    | 1    | 0X  | 0                                 | 2 + 2 x SCY       | 1                | 4                | 6 + 2 x SCY     |  |
| 1                          | 0    | 1    | 10  | 2                                 | 1 + 2 x SCY       | 2                | 4                | 7 + 2 x SCY     |  |
| 1                          | 0    | 1    | 11  | 3                                 | 1 + 2 x SCY       | 3                | 4                | 8 + 2 x SCY     |  |
| 1                          | 1    | 0    | 0X  | 0                                 | 2 + 2 x SCY       | 1                | 8                | 10 + 2 x SCY    |  |
| 1                          | 1    | 0    | 10  | 11/4                              | 134 + 2 x SCY     | 2                | 8                | 11 + 2 x SCY    |  |
| 1                          | 1    | 0    | 11  | 1½                                | 1½ + 2 x SCY      | 2                | 8                | 11 + 2 x SCY    |  |
| 1                          | 1    | 1    | 0X  | 0                                 | 2 + 2 x SCY       | 1                | 8                | 10 + 2 x SCY    |  |
| 1                          | 1    | 1    | 10  | 2                                 | 1 + 2 x SCY       | 2                | 8                | 11 + 2 x SCY    |  |
| 1                          | 1    | 1    | 11  | 3                                 | 1 + 2 x SCY       | 3                | 8                | 12 + 2 x SCY    |  |

## 12.4.2.2 GPCM write signal timing

The basic GPCM write timing parameters that may be set by the ORn attributes are shown in the figure below.

The write access cycle commences upon latching of the memory address (LALE negated), and concludes when LCSn\_B returns high. LBCTL remains stable for the entire cycle to drive data onto any secondary data bus. Write data becomes invalid following the falling edge of TA. LWE\_B may, in some cases, negate high before the end of the write access to provide additional hold time for the external memory.

#### **eLBC** functional description



 $t_{WC}$  = Write cycle time.

 $t_{CSWP}$  = Write chip-select assertion period

 $t_{AWCS}$  = Address valid to write chip-select time.  $t_{WEN}$  = Write eneble negated time wrt t<sub>AWE</sub> = Address valid to write enable time.

chip-select negation time

Figure 12-75. GPCM general write timing parameters

Table 12-191. GPCM write control signal timing

| Option register attributes |      |     |      | Signal Timing (LCLK clock cycles) |                   |                  |                  |                 |  |
|----------------------------|------|-----|------|-----------------------------------|-------------------|------------------|------------------|-----------------|--|
| TRLX                       | XACS | ACS | CSNT | t <sub>AWCS</sub>                 | t <sub>CSWP</sub> | t <sub>AWE</sub> | t <sub>WEN</sub> | t <sub>WC</sub> |  |
| 0                          | 0    | 00  | 0    | 0                                 | 2 + SCY           | 1                | 0                | 2 + SCY         |  |
| 0                          | 0    | 10  | 0    | 1/4                               | 1¾ + SCY          | 1                | 0                | 2 + SCY         |  |
| 0                          | 0    | 11  | 0    | 1/2                               | 1½ + SCY          | 1                | 0                | 2 + SCY         |  |
| 0                          | 1    | 00  | 0    | 0                                 | 2 + SCY           | 1                | 0                | 2 + SCY         |  |
| 0                          | 1    | 10  | 0    | 1                                 | 1 + SCY           | 1                | 0                | 2 + SCY         |  |
| 0                          | 1    | 11  | 0    | 2                                 | 1 + SCY           | 2                | 0                | 3 + SCY         |  |
| 0                          | 0    | 00  | 1    | 0                                 | 2 + SCY           | 1                | 1/4              | 2 + SCY         |  |
| 0                          | 0    | 10  | 1    | 1/4                               | 1½ + SCY          | 1                | 0                | 1¾ + SCY        |  |
| 0                          | 0    | 11  | 1    | 1/2                               | 1¼ + SCY          | 1                | 0                | 1¾ + SCY        |  |
| 0                          | 1    | 00  | 1    | 0                                 | 2 + SCY           | 1                | 1/4              | 2 + SCY         |  |
| 0                          | 1    | 10  | 1    | 1                                 | 3/4 + SCY         | 1                | 0                | 1¾ + SCY        |  |
| 0                          | 1    | 11  | 1    | 2                                 | 3/4 + SCY         | 2                | 0                | 2¾ + SCY        |  |
| 1                          | 0    | 00  | 0    | 0                                 | 2 + 2 x SCY       | 1                | 0                | 2 + 2 x SCY     |  |
| 1                          | 0    | 10  | 0    | 11/4                              | 134 + 2 x SCY     | 2                | 0                | 3 + 2 x SCY     |  |
| 1                          | 0    | 11  | 0    | 1½                                | 1½ + 2 x SCY      | 2                | 0                | 3 + 2 x SCY     |  |
| 1                          | 1    | 00  | 0    | 0                                 | 2 + 2 x SCY       | 1                | 0                | 2 + 2 x SCY     |  |
| 1                          | 1    | 10  | 0    | 2                                 | 1 + 2 x SCY       | 2                | 0                | 3 + 2 x SCY     |  |
| 1                          | 1    | 11  | 0    | 3                                 | 1 + 2 x SCY       | 3                | 0                | 4 + 2 x SCY     |  |

Table 12-191. GPCM write control signal timing (continued)

| Option register attributes |      |     |      | Signal Timing (LCLK clock cycles) |                   |                  |                  |                 |
|----------------------------|------|-----|------|-----------------------------------|-------------------|------------------|------------------|-----------------|
| TRLX                       | XACS | ACS | CSNT | t <sub>AWCS</sub>                 | t <sub>CSWP</sub> | t <sub>AWE</sub> | t <sub>WEN</sub> | t <sub>wc</sub> |
| 1                          | 0    | 00  | 1    | 0                                 | 3 + 2 x SCY       | 1                | 11/4             | 3 + 2 x SCY     |
| 1                          | 0    | 10  | 1    | 11/4                              | 1½ + 2 x SCY      | 2                | 0                | 2¾ + 2 x SCY    |
| 1                          | 0    | 11  | 1    | 1½                                | 1¼ + 2 x SCY      | 2                | 0                | 2¾ + 2 x SCY    |
| 1                          | 1    | 00  | 1    | 0                                 | 3 + 2 x SCY       | 1                | 11/4             | 3 + 2 x SCY     |
| 1                          | 1    | 10  | 1    | 2                                 | 34 + 2 x SCY      | 2                | 0                | 2¾ + 2 x SCY    |
| 1                          | 1    | 11  | 1    | 3                                 | 34 + 2 x SCY      | 3                | 0                | 3¾ + 2 x SCY    |

# 12.4.2.3 Chip-select assertion timing

The banks selected to work with the GPCM support an option to drive the LCS\_B *n* signal with different timings (with respect to the external address/data bus).

LCS\_B *n* can be driven in any of the following ways:

- Simultaneous with the latched memory address. (This refers to the externally latched address and not the address timing on LAD. That is, the chip select does not assert during LALE.)
- One quarter of a clock cycle later.
- One half of a clock cycle later.
- One clock cycle later(for LCRR[CLKDIV] = 2 (clock ratio of 4)), when ORn[XACS] = 1.
- Two clock cycles later, when ORn[XACS] = 1.
- Three clock cycles later, when ORn[XACS] = 1 and ORn[TRLX] = 1.

The timing diagram in Figure 12-73 shows two chip-select assertion timings.

## 12.4.2.3.1 Programmable wait state configuration

The GPCM supports internal generation of transfer acknowledge.

It allows between zero and 30 wait states to be added to an access by programming ORn[SCY] and ORn[TRLX]. Internal generation of transfer acknowledge is enabled if ORn[SETA] = 0. If LGTA\_B is asserted externally two bus clock cycles or more before the wait state counter has expired (to allow for synchronization latency), the current memory cycle is terminated by LGTA\_B; otherwise it is terminated by the expiration of the wait state counter.Regardless of the setting of ORn[SETA], wait states prolong the

#### **eLBC** functional description

assertion duration of both LOE\_B and LWE\_B n in the same manner. When TRLX = 1, the number of wait states inserted by the memory controller is doubled from ORn[SCY] cycles to 2 x ORn[SCY] cycles, allowing a maximum of 30 wait states.

## 12.4.2.3.2 Chip-select and write enable negation timing

The figure below shows a basic connection between the local bus and a static memory device.

In this case, LCS\_B n is connected directly to CE\_B of the memory device. The LWE\_B[0:1] signals are connected to the respective WE\_B[1:0] signals on the memory device where each LWE\_B[0:1] signal corresponds to a different data byte.



Figure 12-76. GPCM basic write timing (XACS = 0, ACS = 00, CSNT = 1, SCY = 1, TRLX = 0)

The timing for LCS\_B n is the same as for the latched address. The strobes for the transaction are supplied by LOE\_B or LWE\_B n, depending on the transaction direction-read or write (write case shown in the figure). ORn[CSNT], along with ORn[TRLX], control the timing for the appropriate strobe negation in write cycles. When this attribute is asserted, the strobe is negated one quarter of a clock before the normal case. For example, when ACS = 00 and CSNT = 1, LWE\_B n is negated one quarter of a clock earlier, as shown in Figure 12-76.

1. LCS\_B *n* is affected by CSNT and TRLX only if ACS[0] is non zero. However, LWE\_B *n* is affected independent of ACS.

- 2. When CSNT attribute is asserted, the strobe is negated one quarter of a clock before the normal case.
- 3. TRLX = 1 in conjunction with CSNT = 1, negates the LCS\_B n and LWE\_B n 1 + 1/4 cycle earlier.

For example, when ACS = 00, CSNT = 1 and TRLX = 0, LWE\_B n is negated one quarter of a clock earlier and LCS\_B n is negated normally as shown in Figure 12-76.

## **12.4.2.3.3** Relaxed timing

ORx[TRLX] is provided for memory systems that require more relaxed timing between signals.

Setting TRLX = 1 has the following effect on timing:

- An additional bus cycle is added between the address and control signals (but only if ACS is not equal to 00).
- The number of wait states specified by SCY is doubled, providing up to 30 wait states.
- The extended hold time on read accesses (EHTR) is extended further.
- LCSn\_B signals are negated one cycle earlier during writes (but only if ACS is not equal to 00).
- LWE\_B[0:1] signals are negated one cycle earlier during writes.

•

#### **eLBC** functional description



Figure 12-77. GPCM relaxed timing back-to-back reads with PLL bypass (XACS = 0, ACS = 1x, SCY = 1, CSNT = 0, TRLX = 1, EHTR = 0)

The example in Figure 12-78 shows address and data multiplexing on LAD for a pair of writes issued consecutively.



Figure 12-78. GPCM relaxed timing back-to-back writes with PLL bypass (XACS = 0, ACS = 1x, SCY = 0, CSNT = 0, TRLX = 1)

When TRLX and CSNT are set in a write access, the LWE\_B[ 0:1] strobe signals are negated one clock earlier than in the normal case. If ACS  $\neq$  00, LCSn\_B is also negated one clock earlier.



Figure 12-79. GPCM relaxed timing write (XACS = 0, ACS = 10, SCY = 0, CSNT = 1, TRLX = 1)



Figure 12-80. GPCM relaxed timing write (XACS = 0, ACS = 00, SCY = 1, CSNT = 1, TRLX = 1)

# 12.4.2.3.4 Output enable (LOE\_B) timing

The timing of the LOE\_B is affected only by TRLX.

It always asserts and negates on the rising edge of the bus clock. LOE\_B asserts either on the rising edge of the bus clock after LCSn\_B is asserted or coinciding with LCSn\_B (if XACS = 1 and ACS = 10 or ACS = 11). Accordingly, assertion of LOE\_B can be delayed (along with the assertion of LCSn\_B by programming TRLX = 1. LOE\_B negates on the rising clock edge coinciding with LCSn\_B negation

## 12.4.2.3.5 Extended hold time on read accesses-GPCM

Slow memory devices that take a long time to disable their data bus drivers on read accesses should choose some combination of ORn[TRLX,EHTR].

Any access following a read access to the slower memory bank is delayed by the number of clock cycles specified in Options register 0 layout for GPCM Mode (eLBC\_ORg0) in addition to any existing bus turnaround cycle. The final bus turnaround cycle is automatically inserted by the eLBC for reads, regardless of the setting of ORn[EHTR].

#### **eLBC** functional description



Figure 12-81. GPCM read followed by read (TRLX = 0, EHTR = 0, fastest timing)



Figure 12-82. GPCM read followed by write (TRLX = 0, EHTR = 1, one-cycle extended hold time on reads)

## 12.4.2.4 External access termination (LGTA\_B)

External access termination is supported by the GPCM using the asynchronous LGTA\_B input signal, which is synchronized and sampled internally by the local bus.

If, during assertion of LCSn\_B, the sampled LGTA\_B signal is asserted, it is converted to an internal generation of transfer acknowledge, which terminates the current GPCM access (regardless of the setting of ORn[SETA]). LGTA\_B must be asserted for at least two bus cycles to be effective. Note that because LGTA\_B is synchronized, bus termination occurs two cycles after LGTA\_B assertion, so in case of read cycle, the device still must drive data as long as LOE\_B is asserted.

The user selects whether transfer acknowledge is generated internally or externally (LGTA\_B) by programming ORn[SETA]. Asserting LGTA\_B always terminates an access, even if ORn[SETA] = 0 (internal transfer acknowledge generation), but it is the only means by which an access can be terminated if ORn[SETA] = 1.

In PLL bypass mode, the timing of LGTA\_B is illustrated by the example in the figure below.



Figure 12-83. External termination of GPCM access (PLL bypass mode)

## 12.4.2.5 GPCM boot chip-select operation

Boot chip-select operation allows address decoding for a boot ROM before system initialization.

LCS0\_B is the boot chip-select output; its operation differs from other external chip-select outputs after a system reset. When the core begins accessing memory after system reset, LCS0\_B is asserted for every local bus access until BR0 or OR0 is reconfigured.

The boot chip-select also provides a programmable port size, which is configured during reset. The boot chip-select does not provide write protection. LCS0\_B operates this way until the first write to OR0 and it can be used as any other chip-select register after the preferred address range is loaded into BR0. After the first write to OR0, the boot chip-select can be restarted only with a hardware reset.

Table 12-192. Boot bank field values after reset for GPCM as boot controller

| Register | Field | Setting          |
|----------|-------|------------------|
| BR0      | BA    | 0000_0000_0000_0 |
|          | PS    | From cfg_rom_loc |
|          | DECC  | 00               |
|          | WP    | 0                |
|          | MSEL  | 000              |
|          | -     | -                |
|          | V     | 1                |
| OR0      | AM    | 0000_0000_0000_0 |
|          | BCTLD | 0                |
|          | CSNT  | 1                |
|          | ACS   | 11               |
|          | XACS  | 1                |
|          | SCY   | 1111             |
|          | SETA  | 0                |
|          | TRLX  | 1                |
|          | EHTR  | 1                |
|          | EAD   | 1                |

## 12.4.3 Flash control machine (FCM)

The FCM provides a glueless interface to parallel-bus NAND Flash EEPROM devices.

The FCM contains three basic configuration register groups-BRn, ORn, and FMR.

The figure below shows a simple connection between an 8-bit port size NAND Flash EEPROM and the eLBC in FCM mode. Commands, address bytes, and data are all transferred on LAD[0:7]<sup>8</sup>, with LFWE\_B asserted for transfers written to the device, or LFRE\_B asserted for transfers read from the device. eLBC signals LFCLE and LFALE determine whether writes are of type command (only LFCLE asserted), address (only LFALE asserted), or write data (neither LFCLE nor LFALE asserted). The NAND Flash RDY/BSY\_B pin is normally open-drain, and should be pulled high by a 4.7-KΩ resistor. On system reset, a global (boot) chip-select is available that provides a boot ROM chip-select (LCS0\_B) prior to the system being fully configured.



Figure 12-84. Local bus to 8-bit FCM device interface

Although LCLK is shown for reference, NAND Flash EEPROMs do not make use of the clock.

<sup>8.</sup> Note bit numbering reversal: LAD[0] (msb) connects to Flash IO[7], while LAD[7] (lsb) connects to IO[0].



Figure 12-85. FCM basic page read timing (PGS = 1, CSCT = 0, CST = 0, CHT = 1, RST = 1, SCY = 0, TRLX = 0, EHTR = 1)

Following the assertion of LALE, FCM asserts LCSn\_B to commence a command sequence to the Flash device. After a delay of t<sub>CSCT</sub>, the first command can be written to the device on assertion of LFWE\_B, followed by any parameters (typically address bytes and data), and concluded with a secondary command. In many cases, the second command initiates a long-running operation inside the Flash device, which pulls the wired-OR pin LFRB\_B low to indicate that the device is busy. Since in Figure 12-85 FCM is now expecting a read response, it takes LBCTL low to turnaround any bus transceivers that are present. Upon LFRB\_B indicating ready status, FCM asserts LFRE\_B repeatedly to recover bytes of read data, and the bytes are stored in eLBC's FCM buffer RAM while an ECC is optionally computed on the bytes transferred. Finally, FCM negates LCSn\_B and delays eLBC by t<sub>EHTR</sub> before any subsequent memory access occurs.

#### 12.4.3.1 FCM buffer RAM

Read and write accesses to eLBC banks controlled by FCM do not access attached NAND Flash EEPROMs directly.

**LBCTL** 

Rather, these accesses read and write the FCM buffer RAM-a single, shared 8-Kbyte space internal to eLBC and mapped by the base address of every FCM bank. Even though each FCM-controlled bank will have a different base address to differentiate it, all accesses to such banks will access the same buffer space. External eLBC signals, such as LALE and LCSn\_B, will not assert upon accesses to the buffer RAM. The FCM buffer RAM is logically divided into two or more buffers, depending on the setting of ORn[PGS], with different buffers being accessible concurrently by software and FCM.

To perform a page read operation from a NAND Flash device, software initializes the FCM command, mode, and address registers, before issuing a special operation (FMR[OP] set non-zero) to a particular FCM-controlled bank. FCM will execute the sequence of op-codes held in FIR, reading data from the Flash device into the shared buffer RAM. While this read is taking place, software is free to access any data stored in other, currently inactive buffers of the FCM buffer RAM through reads or writes to any bank controlled by FCM. If command completion interrupts are enabled, an interrupt will be generated once FCM has completed the read. When FCM has completed its last command, software can switch to the newly read buffer and issue further commands.

To perform a page write operation, software first prepares data to be written in a fresh buffer. Then, the FCM command, mode, and address registers are initialized, and a special operation (FMR[OP] set non-zero) is issued to a particular FCM-controlled bank. FCM will execute the sequence of op-codes held in FIR, writing data from shared buffer RAM to the Flash device. To ensure that the device is enabled for programming, software must initialize FMR[OP] = 11, which prevents assertion of LFWP\_B during the write. While this write is taking place, software is free to access any data stored in other, currently inactive buffers of the FCM buffer RAM through reads or writes to any bank controlled by FCM. When FCM has completed its last command, software can re-use the previously written buffer and issue further commands.

See Boot block loading into the FCM buffer RAM for a description of the shared buffer RAM layout during boot.

# 12.4.3.1.1 Buffer layout and page mapping for small-page NAND flash devices

The FCM buffer space is divided into eight 1-Kbyte buffers for small-page devices (ORn[PGS] = 0), mapped as shown in Figure 12-86.

Each page in a small-page NAND Flash comprises 528 bytes, where 512 bytes appear as main region data, and 16 bytes appear as spare region data. The EEPROM's page numbered P is associated with buffer number ( $P \mod 8$ ), where P = FPAR[PI]. Since the bank size set by ORn[AM] will be greater than 8 Kbytes, an identical image of the FCM

buffer RAM appears replicated every 8 Kbytes throughout the bank address space. It is recommended that the bank size be set to 32 Kbytes, which covers a single NAND Flash block for small-page devices.

For FCM commands, register FPAR sets the page address and, therefore, also the buffer number. In the case that FBCR[BC] = 0, FCM transfers an entire page, comprising the 512-byte main region followed by the 16-byte spare region; the 496-byte reserved region is not accessible, and remains undefined for software. However, for commands given a specific byte count in FBCR[BC], FPAR[MS] locates the starting address in either the main region (MS = 0) or the spare region (MS = 1). Where different eLBC banks control both small and large-page devices, a large-page 4-Kbyte buffer must be assigned to either the first 4 or last 4 small-page buffers.



Figure 12-86. FCM buffer RAM memory map for small-page (512-byte page) NAND flash devices

# 12.4.3.1.2 Buffer layout and page mapping for large-page NAND flash devices

The FCM buffer space is divided into two 4 Kbyte buffers for large-page devices (ORn[PGS] = 1), mapped as shown in Figure 12-87.

Each page in a large-page NAND Flash comprises 2112 bytes, where 2048 bytes appear as main region data, and 64 bytes appear as spare region data. The EEPROM's page numbered P is associated with buffer number ( $P \mod 2$ ), where P = FPAR[PI]. Since the bank size set by ORn[AM] will be greater than 8 Kbytes, an identical image of the FCM

buffer RAM appears replicated every 8 Kbytes throughout the bank address space. It is recommended that the bank size be set to 256 Kbytes, which covers a single NAND Flash block for large-page devices.

For FCM commands, register FPAR sets the page address and, therefore, also the buffer number. In the case that FBCR[BC] = 0, FCM transfers an entire page, comprising the 2048-byte main region followed by the 64-byte spare region; the 1984-byte reserved region is not accessed, and remains undefined for software. However, for commands given a specific byte count in FBCR[BC], FPAR[MS] locates the starting address in either the main region (MS = 0) or the spare region (MS = 1). Where different eLBC banks control both small and large-page devices, a large-page 4 Kbyte buffer must be assigned to either the first 4 or last 4 small-page buffers.



Figure 12-87. FCM buffer RAM memory map for large-page (2-Kbyte page) NAND flash devices

## 12.4.3.1.3 Error correcting codes and the spare region

The FCM's ECC engine makes use of data in the NAND Flash spare region to store precomputed ECC code words.

ECC is calculated in a single pass over blocks of 512 bytes of data in the main region. The setting of FMR[ECCM] determines the location of the 24-bit ECC in the spare region.

The basic ECC algorithm is depicted in Figure 12-88. The stream of data bytes is considered to form a matrix having 8 columns (corresponding with the device bus IO[7:0] or IO[15:8]) and 512 rows (corresponding with each byte in the ECC block). Six bits of parity,  $\{P_4, P_4', P_2, P_2', P_1, P_1'\}$ , are calculated across the columns, and at most 18 bits of parity  $\{P_{2048}, P_{2048}', ..., P_{16}, P_{16}', P_8, P_8'\}$  are calculated across the rows to create a 24-bit Hamming code for the data block. In this calculation, parity bit  $P_N$  is the exclusive-OR of every alternate *N*-bit group of bits positioned at even intervals (starting at *N*-bit group 0, then continuing to group 2, 4, and so on), while parity bit  $P_N$  is the exclusive-OR of every alternate *N*-bit group of bits positioned at odd intervals (starting at *N*-bit group 1, then continuing to group 3, 5, and so on).



Figure 12-88. FCM ECC calculation

The 24-bit ECC code word format is shown in Table 12-193 for normal ECC polarity. Setting LBCR[EPAR] = 1 changes ECC polarity, and thus omits negation of each  $P_N$  and  $P_N$  bit.

Table 12-193. ECC layout for LBCR[EPAR] = 0 (~ represents logical negation)

|     | 0 (MSB)            | 1                    | 2                 | 3                   | 4                 | 5                   | 6                  | 7 (LSB)              |
|-----|--------------------|----------------------|-------------------|---------------------|-------------------|---------------------|--------------------|----------------------|
| EC0 | ~P <sub>64</sub>   | ~P <sub>64</sub> '   | ~P <sub>32</sub>  | ~P <sub>32</sub> '  | ~P <sub>16</sub>  | ~P <sub>16</sub> '  | ~P <sub>8</sub>    | ~P8'                 |
| EC1 | ~P <sub>1024</sub> | ~P <sub>1024</sub> ' | ~P <sub>512</sub> | ~P <sub>512</sub> ' | ~P <sub>256</sub> | ~P <sub>256</sub> ' | ~P <sub>128</sub>  | ~P <sub>128</sub> '  |
| EC2 | ~P <sub>4</sub>    | ~P <sub>4</sub> '    | ~P <sub>2</sub>   | ~P <sub>2</sub> '   | ~P <sub>1</sub>   | ~P <sub>1</sub> '   | ~P <sub>2048</sub> | ~P <sub>2048</sub> ' |

The placement of ECC code words in relation to FMR[ECCM] is shown in Table 12-194. For small-page devices, only a single 512-byte main region is ECC-protected. For largepage devices, there are four adjacent main regions, and each has a 16-byte spare region-of which only one is shown in the figure. If eLBC is configured to generate ECC (BRn[DECC] = 10), FCM will substitute on full-page write transfers the three code word bytes in place of the spare region data originally provided at the locations shown in Table 12-194. Transfers shorter than a full page, however, require software to prepare the appropriate ECC in the spare region. Similarly, FCM can check and correct bit errors on full-page reads if BRn[DECC] = 01 or 10. A correctable error is a single bit error in any 512-byte block of main region data, as judged by comparison of a regenerated ECC with the ECC retrieved from the spare region, or a single bit error in the retrieved ECC only. Bit errors in the main region are corrected before FCM completes its final read transfer and signals an event in LTESR[CC]. Errors that appear more complex (two or more bits in error per 512-byte block) are not corrected, but are flagged as parity errors by FCM. The bit vector in LTEATR[PB] can be checked to determine which 512-byte blocks in a large-page NAND Flash main region were found to be non-correctable.

Table 12-194. ECC placement in NAND flash spare regions in relation to FMR[ECCM]

| ECCM | Byte 0      | Byte 511 | Other<br>Mains | Spare 0 | 5 | 6   | 7   | 8   | 9   | 10  | 11 | 12 | 13 | 14 | 15 |
|------|-------------|----------|----------------|---------|---|-----|-----|-----|-----|-----|----|----|----|----|----|
| 0    | Main Region |          |                | -       | • | EC0 | EC1 | EC2 | -   |     |    | •  |    |    |    |
| 1    | Main Region |          |                | -       |   |     |     | EC0 | EC1 | EC2 | -  |    |    |    |    |

## 12.4.3.2 Programming FCM

FCM has a fully general command and data transfer sequencer that caters for both common and specific/proprietary NAND Flash command sequences.

The command sequencer reads a program out of the FIR register, which can hold up to 8 instructions, each represented by a 4-bit op-code, as illustrated in Figure 12-89. The first instruction executed is read from FIR[OP0], the next is read from FIR[OP1], and likewise to subsequent instructions, ending at FIR[OP7] or until the only instructions remaining are NOPs. If FIR contains nothing but NOP instructions, FCM will not assert LCSn\_B, otherwise, LCSn\_B is asserted prior to the first instruction and remains asserted until the last instruction has completed. If LTESR[CC] is enabled, completion of the last instruction will trigger a command completion event interrupt from eLBC.

Prior to executing a sequence, necessary operands for the instructions will need to be set in the FMR, FCR, MDR, FBCR, FBAR, and FPAR registers. The ASO-AS3 address and data pointers associated with FCM's use of MDR all reset to select ASO at the start of the instruction sequence. A complete list of op-codes can be found in Flash instruction register (eLBC\_FIR).



Figure 12-89. FCM instruction sequencer mechanism

#### 12.4.3.2.1 FCM command instructions

There are two kinds of command instruction:

- Commands that issue immediately-CM0, CM1, CM2, and CM3. These commands write a single command byte by asserting LFCLE and LFWE\_B while driving an 8-bit command onto LAD[0:7]. Op-code CMn sources its command byte from field FCR[CMDn], therefore up to four different commands can be issued in any FCM instruction sequence.
- Commands that wait for LFRB\_B to be sampled high (EEPROM in ready state) before issuing-CW0, and CW1. These commands first poll the LFRB\_B pin, waiting for it to go high, before writing a single command byte onto LAD[0:7], sourced from FCR[CMDn] for op-code CWn. It is necessary to use CWn op-codes whenever the EEPROM is expected to be in a busy state (such as following a page read, block erase, or program operation) and therefore initially unresponsive to commands. To avoid deadlock in cases where the device is already available, FCM does not expect a transition on LFRB\_B. Rather, FCM waits for 8 x (2 + ORn[SCY]) clock cycles

(when ORn[TRLX] = 0) or  $16 \times (2 + ORn[SCY])$  clock cycles (when ORn[TRLX] = 1) before sampling the level of LFRB\_B. If the level of LFRB\_B does not return high before a time-out set by FMR[CWTO] occurs, FCM proceeds to issue the command normally, and a FCT event is issued to LTESR.

The manufacturer's datasheet should be consulted to determine values for programming into the FCR register, and whether a given command in the sequence is expected to initiate busy device behavior.

#### 12.4.3.2.2 FCM no-operation instruction

A NOP instruction that appears in FIR ahead of the last instruction is executed with the timing of a regular command instruction, but neither LFCLE nor LFWE\_B are asserted.

Thus a NOP instruction may be used to insert a pause matching the time taken for a regular command write.

#### 12.4.3.2.3 FCM address instructions

Address instructions are used to issue addresses to the NAND Flash EEPROM.

A complete device address is formed from a sequence of one or more bytes, each written onto LAD[0:7] with LFALE and LFWE\_B asserted together. There are three kinds of address generation provided:

- Column address-CA. A column address comprises one byte (ORn[PGS] = 0) or two bytes (ORn[PGS] = 1) locating the starting byte or word to be transferred in the next page read or write sequence. FPAR[CI] sets the value of the column index provided that FBCR[BC] is non-zero. In the case that FBCR[BC] = 0, a column index of zero is issued to the device, regardless of the value in FPAR[CI].
- Page address-PA. A page address comprises 2, 3, or 4 bytes, depending on the setting of FMR[AL], and locates the data page in the NAND Flash address space. The complete page address is the concatenation of the block index, read from FBAR[BLK], with the page-in-block index, read from FPAR[PI]. The page address length set in FMR[AL] should correspond with the size of EEPROM being accessed. Similarly, the block index in FBAR[BLK] must not exceed the maximum block index for the device, as most devices require reserved address bits to be written as zero.
- User-defined address-UA. This instruction allows the FCM to write a user-defined address byte, which is read from the next AS field in MDR, starting at MDR[AS0]. Each subsequent UA instruction reads an adjacent AS field in MDR, until all four AS bytes (MDR[AS0], MDR[AS1], MDR[AS2], MDR[AS3]) have been sent; a fifth and any following UA instructions send zero as the address byte. Note that each UA

instruction advances the MDR pointer for writes by one byte, and therefore a mix of UA and WS instructions can consume adjacent bytes from MDR.

#### 12.4.3.2.4 FCM data read instructions

Data read instructions assert LFRE\_B repeatedly to transfer one or more bytes of read data from the NAND Flash EEPROM.

Data read instructions are distinguished by their data destination:

- Read data to buffer RAM immediately- RB. This instruction reads FBCR[BC] bytes of data into the current FCM RAM buffer addressed by FPAR. If FBCR[BC] = 0, an entire page (including spare region) is transferred in a burst, starting at the page boundary, and the ECC calculation is checked against the ECC stored in the spare region. Correctable ECC errors are corrected; other errors may cause an interrupt if enabled. If the value of FBCR[BC] takes the read pointer beyond the end of the spare region in the buffer, FCM discards any excess bytes read.
- Read data/status to MDR immediately- RS. This instruction asserts LFRE\_B exactly once to read one byte (8-bit port size) of data into the next AS field of MDR. Reads beyond the fourth byte of MDR are discarded. The MDR read pointer is independent of the MDR write pointer used by UA and WS instructions.
- Read data to buffer RAM once waited on ready- RBW. This instruction first polls the LFRB\_B pin, waiting for it to go high, before proceeding with a read to buffer as described for the RB instruction. Sampling and time-outs for polling the LFRB\_B pin follow the behavior of CWn instructions.
- Read data/status to MDR once waited on ready- RSW. This instruction first polls the LFRB\_B pin, waiting for it to go high, before proceeding with a status read to MDR as described for the RS instruction. Sampling and time-outs for polling the LFRB\_B pin follow the behavior of CWn instructions.

#### 12.4.3.2.5 FCM data write instructions

Data write instructions assert LFWE\_B repeatedly (with LFCLE and LFALE both negated) to transfer one or more bytes of write data to the NAND Flash EEPROM.

Data write instructions are distinguished by their data source:

• Write data from FCM buffer RAM-WB. This instruction writes FBCR[BC] bytes of data from the current FCM RAM buffer addressed by FPAR. If FBCR[BC] = 0, an entire page (including spare region) is transferred in a burst, starting at the page boundary, and the ECC calculation is stored in the and spare region in accordance with the setting of FMR[ECCM]. If the value of FBCR[BC] takes the write pointer

- beyond the end of the spare region in the buffer, the value of data written by FCM is undefined.
- Write data/status from MDR-WS. This instruction asserts LFWE\_B exactly once to
  write one byte (8-bit port size) of data taken from the next AS field of MDR.
  Attempts to write beyond four bytes of MDR has the effect of writing zeros. The
  MDR write pointer is independent of the MDR read pointer used by RS and RSW
  instructions.

## 12.4.3.3 FCM signal timing

If BRn[MSEL] selects the FCM, the attributes for the memory cycle are taken from ORn. These attributes include the CSCT, CST, CHT, RST, SCY, TRLX, and EHTR fields.

## 12.4.3.3.1 FCM chip-select timing

The timing of LCS $n_B$  assertion in FCM mode is illustrated by the timing diagram in Figure 12-85.

 $n_{\rm B}$  is asserted immediately following LALE negation, and remains asserted until the last instruction in FIR has completed.

The delay,  $t_{CSCT}$ , between  $n_B$  assertion and commencement of the first NAND Flash instruction is controlled by ORn[CSCT] and ORn[TRLX], as shown in Table 12-195. ORn[CSCT] should be set in accordance with the NAND Flash EEPROM chip-select to WE\_B set-up time specification.

| ORn[TRLX] | ORn[CSCT] | LCSn_B to First Command Delay |
|-----------|-----------|-------------------------------|
| 0         | 0         | 1 LCLK clock cycle            |
| 0         | 1         | 4 LCLK clock cycles           |
| 1         | 0         | 2 LCLK clock cycles           |
| 1         | 1         | 8 LCLK clock cycles           |

Table 12-195. FCM chip-select to first command timing

## 12.4.3.3.2 FCM command, address, and write data timing

The FCM command (CM0-CM3, CW0, CW1), address (CA, PA, UA), and data write (WB, WS) instructions all share the same basic timing attributes.

Assertion of LFWE\_B initiates transfer via LAD[0:7], and the options in OR*n* for FCM mode establish the set-up, hold, and wait state timings with respect to LFWE\_B, as shown in Figure 12-90.

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013



Figure 12-90. Timing of FCM command/address and write data cycles (for TRLX = 0, CHT = 0, CST = 1, SCY = 1)

Table 12-196. FCM command, address, and write data timing parameters

| Option | Register A | ttributes |                  | Timing Parameter (LCLK Clock Cycles) <sup>1</sup> |                 |                 |             |                  |  |  |  |  |  |
|--------|------------|-----------|------------------|---------------------------------------------------|-----------------|-----------------|-------------|------------------|--|--|--|--|--|
| TRLX   | СНТ        | CST       | t <sub>CST</sub> | t <sub>CHT</sub>                                  | t <sub>WS</sub> | t <sub>WP</sub> | twc         | t <sub>ADL</sub> |  |  |  |  |  |
| 0      | 0          | 0         | 0                | ½                                                 | SCY             | 1½ + SCY        | 2 + SCY     | 4 x (2 + SCY)    |  |  |  |  |  |
| 0      | 0          | 1         | Â1⁄4             | Â1/2                                              | SCY             | 1¼ + SCY        | 2 + SCY     | 4 x (2 + SCY)    |  |  |  |  |  |
| 0      | 1          | 0         | 0                | 1                                                 | SCY             | 1 + SCY         | 2 + SCY     | 4 x (2 + SCY)    |  |  |  |  |  |
| 0      | 1          | 1         | Â1⁄4             | 1                                                 | SCY             | ¾ + SCY         | 2 + SCY     | 4 x (2 + SCY)    |  |  |  |  |  |
| 1      | 0          | 0         | ½                | 1½                                                | 2xSCY           | 1 + 2 x SCY     | 3 + 2 x SCY | 8 x (2 + SCY)    |  |  |  |  |  |
| 1      | 0          | 1         | 1                | 1½                                                | 2xSCY           | ½ + 2 x SCY     | 3 + 2 x SCY | 8 x (2 + SCY)    |  |  |  |  |  |
| 1      | 1          | 0         | ½                | 2                                                 | 2xSCY           | ½ + 2 x SCY     | 3 + 2 x SCY | 8 x (2 + SCY)    |  |  |  |  |  |
| 1      | 1          | 1         | 1                | 2                                                 | 2xSCY           | 2 x SCY         | 3 + 2 x SCY | 8 x (2 + SCY)    |  |  |  |  |  |

<sup>1.</sup> In the parameters, SCY refers to a delay of ORn[SCY] clock cycles.

An example of minimum delay command timing appears in the figure below. Note that the set-up, wait-state, and hold timing of command, address, and write data cycles with respect to LFWE\_B assertion are all identical, and that the minimum cycle extends for two LCLK clock cycles.



Figure 12-91. Example of FCM command and address timing with minimum delay parameters (for TRLX = 0, CHT = 0, CST = 0, SCY = 0)



Figure 12-92. Example of FCM command and address timing with relaxed parameters (for TRLX = 1, CHT = 0, CST = 1, SCY = 2)

## 12.4.3.3.3 FCM ready/busy timing

Instructions CW0, CW1, RBW, and RSW force FCM to observe the state of the LFRB\_B pin, which may be driven low by a long-latency NAND Flash operation, such as a page read.

Following the issue of such commands, FCM waits as shown in Figure 12-93 before sampling the state of LFRB\_B. This guards against observing LFRB\_B before it has been properly driven low by the device, but does not preclude LFRB\_B from remaining high after a command. In addition, FCM samples and compares the state of LFRB\_B on two consecutive cycles of LCLK to filter out noise on this signal as it rises to the ready state (LFRB\_B = 1).



Figure 12-93. FCM delay prior to sampling LFRB\_B state

## 12.4.3.3.4 FCM read data timing

The timing for read data transfers is shown in the figure below.

Upon assertion of LFRE\_B, the Flash device will enable its output drivers and drive valid read data while LFRE\_B is held low.

FCM samples read data on the rising edge of LFRE\_B, which follows an optional number of wait states. Note that FCM will delay the first read if a RBW or RSW instruction is issued, in which case LFRB\_B sample timing takes effect (see FCM ready/busy timing).



Notes:  $tRP = \overline{LFRE}$  pulse time, read period. tWS = Read wait state time.  $tRHT = \overline{LFRE}$  hold time. tRC = Read data cycle time. tWRT = Write to read turnaround time.

Figure 12-94. FCM read data timing (for TRLX = 0, RST = 0, SCY = 1)

Table 12-197. FCM read data timing parameters

| Option Regis | ster Attributes | Timing Parameter (LCLK Clock Cycles) <sup>1</sup> |                  |                 |                 |                  |  |  |  |  |
|--------------|-----------------|---------------------------------------------------|------------------|-----------------|-----------------|------------------|--|--|--|--|
| TRLX         | RST             | t <sub>RP</sub>                                   | t <sub>RHT</sub> | t <sub>WS</sub> | t <sub>RC</sub> | t <sub>WRT</sub> |  |  |  |  |
| 0            | 0               | 34 + SCY                                          | 1                | SCY             | 2 + SCY         | 4 x (2 + SCY)    |  |  |  |  |
| 0            | 1               | 1 + SCY                                           | 1                | SCY             | 2 + SCY         | 4 x (2 + SCY)    |  |  |  |  |
| 1            | 0               | ½ + 2 x SCY                                       | 2                | 2 x SCY         | 3 + 2 x SCY     | 8 x (2 + SCY)    |  |  |  |  |
| 1            | 1               | 1 + 2 x SCY                                       | 2                | 2 x SCY         | 3 + 2 x SCY     | 8 x (2 + SCY)    |  |  |  |  |

1. In the parameters, SCY refers to a delay of ORn[SCY] clock cycles.

## 12.4.3.3.5 FCM extended read hold timing

Allowance for slow output driver turn-off when reading NAND Flash EEPROMs is made via setting of ORn[EHTR] and ORn[TRLX].

The extended read data hold time, shown at  $t_{\rm EHTR}$  in Figure 12-85 and Figure 12-95, is a delay inserted by FCM between the last data read and another eLBC memory access (requiring LALE assertion). LCS $n_{\rm EHTR}$  is negated during  $t_{\rm EHTR}$  to allow external devices and bus transceivers time to disable their drivers.



Figure 12-95. FCM read data timing with extended hold time (for TRLX = 0, EHTR = 1, RST = 1, SCY = 1)

## 12.4.3.4 FCM boot chip-select operation

Boot chip-select operation allows address decoding for a boot ROM before system initialization.

LCS0\_B is the boot chip-select output; its operation differs from other external chip-select outputs after a system reset. When the core begins accessing memory after system reset, LCS0\_B is asserted initially to load a 4-Kbyte boot block into the FCM buffer RAM, but core instruction fetches occur from the buffer RAM.

#### 12.4.3.4.1 FCM bank 0 reset initialization

The boot chip-select also provides a programmable port size, which is configured during reset.

The boot chip-select does not provide write protection. LCS0\_B operates this way until the first write to OR0 and it can be used as any other chip-select register after the preferred address range is loaded into BR0. After the first write to OR0, the boot chip-select can be restarted only with a hardware reset.

Setting Register **Field** BR0 BA 0000\_0000\_0000\_0000\_0 PS From cfg\_rom\_loc **DECC** From cfg\_elbc\_ecc WP 0 **MSEL** 001 OR<sub>0</sub> AM 0000 0000 0000 0000 0 **BCTLD** PGS From cfg\_rom\_loc **CSCT** CST CHT 1 **RST** SCY 010

Table 12-198. Boot bank field values after reset for FCM as boot controller

## 12.4.3.4.2 Boot block loading into the FCM buffer RAM

TRLX EHTR

If FCM is selected as the boot ROM controller from power-on-reset configuration, eLBC will automatically load from bank 0 a single 4 Kbyte page of boot code into the FCM buffer RAM during HRESET\_B.

The CPU can execute boot code directly from the FCM buffer RAM, but must ensure that any further data read from the NAND Flash EEPROM is transferred under software control in order to continue the bootstrap process.

Since OR0[AM] is initially cleared during reset, all CPU fetches to eLBC will access the FCM buffer RAM, which appears in the memory map as a 4-Kbyte RAM. No NAND Flash spare regions are mapped during boot, therefore only 4 Kbytes of contiguous, main region data, loaded from the first pages of the boot block, are accessible in eLBC bank 0.



Figure 12-96. FCM buffer RAM memory map during boot loading

The process for booting is as follows:

- 1. Following negation of HRESET\_B, eLBC is released from reset and commences automatic boot block loading if FCM is selected as the boot ROM location. Small-page or large-page, 8-bit NAND Flash devices can be used for boot loading when enabled with LCS0\_B. eLBC drives LFWP\_B low during boot accesses to prevent accidental erasure of the NAND Flash boot ROM.
- 2. FCM starts searching for a valid boot block at block index 0.
- 3. FCM reads the spare regions of the first two pages of the current block, checking the bad block indication (BI) bytes to validate the block for reading. BI bytes must all hold the value 0xFF for the page to be considered readable.
  - For small-page devices, BI is a single byte read from spare region byte offset 5.
  - For large-page devices, BI is a single byte read from spare region byte offset 0.

If either of the first two pages of the current block are marked invalid, then the boot block index is incremented by 1, and FCM repeats step 3. eLBC will continue searching for a bootable block indefinitely, therefore at least one block must be marked valid for boot loading to proceed. At the conclusion of the boot block search, the value of FBAR[BLK] points to the boot block.

- 4. The FCM optionally performs ECC checking at boot time depending on the configuration selected during reset. If ECC checking is enabled, the FCM recovers from the spare region the stored ECC for each 512-byte block of boot data. The boot block must be prepared with ECC protection. During ECC generation, software should use FMR[ECCM] = 0 for small-page devices, and FMR[ECCM] = 1 for large-page devices.
- 5. FCM performs a sequence of random-access page reads, reading entire pages from the boot block until 4 Kbytes have been saved to the FCM buffer RAM. If ECC checking is enabled, the ECC of each 512-byte region is verified and single-bit errors are corrected if possible. If FCM is unable to correct ECC errors, eLBC halts the boot process and signals an unrecoverable error by asserting the *hreset\_req\_B* signal.
- 6. The CPU now commences fetching instructions, in random order, from the FCM buffer RAM. This first-level boot loader typically copies a secondary boot loader into system memory, and continues booting from there. Boot software must clear FMR[BOOT] to enable normal operation of FCM.

## 12.4.4 User-programmable machines (UPMs)

UPMs are flexible interfaces that connect to a wide range of memory devices.

At the heart of each UPM is an internal RAM array that specifies the logical value driven on the external memory control signals (LCSn\_B, LBS\_B[ 0:1] and LGPL[0:5]) for a given clock cycle. Each word in the RAM array provides bits that allow a memory access to be controlled with a resolution of up to one quarter of the external bus clock period on the byte-select and chip-select lines. A gap of 2 dead LCLK cycles is present on the UPM interface between UPM transactions.

#### NOTE

If the LGPL4/ LGTA\_B/ LFRB\_B/LUPWAIT/LPBSE signal is used as both an input and an output, a weak pull-up is required. See the chip hardware specifications for details regarding termination options.



Figure 12-97. User-programmable machine functional block diagram

The following events initiate a UPM cycle:

- Any internal device requests an external memory access to an address space mapped to a chip-select serviced by the UPM
- A UPM refresh timer expires and requests a transaction, such as a DRAM refresh
- A bus monitor time-out error during a normal UPM cycle redirects the UPM to execute an exception sequence

The RAM array contains 64 words of 32-bits each. The signal timing generator loads the RAM word from the RAM array to drive the general-purpose lines, byte-selects, and chip-selects. If the UPM reads a RAM word with WAEN set, the external LUPWAIT signal is sampled and synchronized by the memory controller and the current request is frozen.

## **12.4.4.1 UPM requests**

A special pattern location in the RAM array is associated with each of the possible UPM requests.

An internal device's request for a memory access initiates one of the following patterns (MxMR[OP] = 00):

• Read single-beat pattern (RSS)

- Read burst cycle pattern (RBS)
- Write single-beat pattern (WSS)
- Write burst cycle pattern (WBS)

A UPM refresh timer request pattern initiates a refresh timer pattern (RTS).

An exception (caused by a bus monitor time-out error) occurring while another UPM pattern is running initiates an exception condition pattern (EXS).

The figure and table below show the start addresses of these patterns in the UPM RAM, according to cycle type. RUN commands (MxMR[OP] = 11), however, can initiate patterns starting at any of the 64 UPM RAM words.



Figure 12-98. RAM array indexing

Table 12-199. UPM routines start addresses

| UPM Routine               | Routine Start Address |
|---------------------------|-----------------------|
| Read single-beat (RSS)    | 0x00                  |
| Read burst (RBS)          | 0x08                  |
| Write single-beat (WSS)   | 0x18                  |
| Write burst (WBS)         | 0x20                  |
| Refresh timer (RTS)       | 0x30                  |
| Exception condition (EXS) | 0x3C                  |

## 12.4.4.1.1 Memory access requests

The user must ensure that the UPM is appropriately initialized before a request occurs.

The UPM supports two types of memory reads and writes:

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

- A single-beat transfer transfers one operand consisting of up to a single word (dependent on port size). A single-beat cycle starts with one transfer start and ends with one transfer acknowledge.
- A burst transfer transfers exactly 4 double words regardless of port size. For 32-bit accesses, the burst cycle starts with one transfer start but ends after eight transfer acknowledges, whereas an 8-bit device requires 32 transfer acknowledges.

The user must ensure that patterns for single-beat transfers contain one, and only one, transfer acknowledge (UTA bit in RAM word set high) and for a burst transfer, contain the exact number of transfer acknowledges required.

Any transfers that do not naturally fit single or burst transfers are synthesized as a series of single transfers. These accesses are treated by the UPM as back-to-back, single-beat transfers. Burst transfers can also be inhibited by setting ORn[BI]. Burst performance can be achieved by ensuring that UPM transactions are 32-byte aligned with a transaction size being some multiple of 32-bytes, which is a natural fit for cache-line transfers, for example.

#### 12.4.4.1.2 UPM refresh timer requests

Each UPM contains a refresh timer that can be programmed to generate refresh service requests of a particular pattern in the RAM array.

The figure below shows the clock division hardware associated with memory refresh timer request generation. The UPM refresh timer register (LURT) defines the period for the timers associated with all three UPMs.



Figure 12-99. Memory refresh timer request block diagram

By default, all local bus refreshes are performed using the refresh pattern of UPMA. This means that if refresh is required, MAMR[RFEN] must be set. It also means that only one refresh routine should be programmed and be placed in UPMA, which serves as the refresh executor. Any banks assigned to a UPM are provided with the common UPMA refresh pattern if the RFEN bit of the corresponding UPM is set, concurrently. UPMA assigned banks, therefore, always receive refresh services when MAMR[RFEN] is set, while UPMB and UPMC assigned banks also receive (the same) refresh services if the corresponding MxMR[RFEN] bits are set. In this scenario, more than one chip select may assert at the same time, as refresh pattern runs for all banks assigned to UPM with RFEN bit set.

## 12.4.4.1.3 Software requests-RUN command

Software can start a request to the UPM by issuing a RUN command to the UPM.

Some memory devices have their own signal handshaking protocol to put them into special modes, such as self-refresh mode.

For these special cycles, the user creates a special RAM pattern that can be stored in any unused areas in the UPM RAM. Then a RUN command is used to run the cycle. The UPM runs the pattern beginning at the specified RAM location until it encounters a RAM word with its LAST bit set. The RUN command is issued by setting MxMR[OP] = 11 and accessing UPMn memory region with any write transaction that hits the corresponding UPM machine. MxMR[MAD] determines the starting address in the RAM array for the pattern.

Note that transfer acknowledges (UTA bit in the RAM word) are ignored for software (RUN command) requests, and hence the LAD signals remain high-impedance unless the normal initial LALE occurs or the RUN pattern causes assertion of LALE to occur on changes to the RAM word AMX field.

#### 12.4.4.1.4 Exception requests

When the eLBC under UPM control initiates an access to a memory device and an exception occurs (bus monitor time-out), the UPM provides a mechanism by which memory control signals can meet the device's timing requirements without losing data.

The mechanism is the exception pattern that defines how the UPM negates its signals in a controlled manner.

# 12.4.4.2 Programming the UPMs

The UPM is a micro sequencer that requires microinstructions or RAM words to generate signal timings for different memory cycles.

Follow these steps to program the UPMs:

- 1. Set up BRn and ORn registers.
- 2. Write patterns into the RAM array.
- 3. Program MRTPR, LURT and MAMR[RFEN] if refresh is required.
- 4. Program M*x*MR.

Patterns are written to the RAM array by setting MxMR[OP] = 01 and accessing the UPM with any write transaction that hits the relevant chip select. The entire array is thus programmed by an alternating series of writes: to MDR (RAM word to be written) each

time followed by a read from MDR and then followed by a (dummy) write transaction to the relevant UPM assigned bank. A read from MDR is required to ensure that the MDR update has occurred prior to the (dummy) write transaction.

RAM array contents may also be read for debug purposes, for example, by alternating dummy read transactions, each time followed by reads of MDR (when MxMR[OP] = 10).

#### NOTE

MxMR/MDR registers should not be updated while dummy read/write access is still in progress. If the MxMR[MAD] is incremented then the previous dummy transaction is already completed.

In order to enforce proper ordering between updates to the MxMR/MDR register and the dummy accesses to the UPM memory region, two rules must be followed:

- Since the result of any update to the MxMR/MDR register must be in effect before the dummy read or write to the UPM region, a write to MxMR/MDR should be followed immediately by a read of MxMR/MDR.
- The UPM memory region should have the same MMU settings as the memory region containing the MxMR configuration register; both should be mapped by the MMU as cache-inhibited and guarded. This prevents the CPU from re-ordering a read of the UPM memory around the read of MxMR. Once the programming of the UPM array is complete the MMU setting for the associated address range can be set to the proper mode for normal operation, such as cacheable and copyback.

For proper signalling, the following guidelines must be followed while programming UPM RAM words:

- For UPM reads, program UTA and LAST in the same or consecutive RAM words.
- For UPM burst reads, program last UTA and LAST in the same or consecutive RAM words.
- For UPM writes, program UTA and LAST in the same RAM word.
- For UPM burst writes, program last UTA and LAST in the same RAM word.

# 12.4.4.2.1 UPM programming example (two sequential writes to the RAM array)

The following example further illustrates the steps required to perform two writes to the RAM array at non-sequential addresses assuming that the relevant BRn and ORn registers have been previously set up:

- 1. Program MxMR for the first write (with the desired RAM array address).
- 2. Write pattern/data to MDR to ensure that the MxMR has already been updated with the desired configuration.
- 3. Read MDR to ensure that the MDR has already been updated with the desired pattern. (Or, read MxMR register if step 2 is not performed.)
- 4. Perform a dummy write transaction.
- 5. Read/check MxMR[MAD]. If incremented, the previous dummy write transaction is completed; proceed to step 6. Repeat step 5 until incremented.
- 6. Program MxMR for the second write with the desired RAM array address.
- 7. Write pattern/data to MDR to ensure that the MxMR has already been updated with the desired configuration.
- 8. Read MDR to ensure that the MDR has already been updated with the desired pattern.
- 9. Perform a dummy write transaction.
- 10. Read/check MxMR[MAD]. If incremented, the previous dummy write transaction is completed.

Note that if steps 1 and 2 or steps 6 and 7 are reversed, step 3 or 8 (as appropriate) is replaced by the following:

• Read MxMR to ensure that the MxMR has already been updated with the desired configuration.

# 12.4.4.2.2 UPM programming example (two sequential reads from the RAM array)

RAM array contents may also be read for debug purposes, for example, by alternating dummy read transactions, each time followed by reads of MDR (MxMR[OP] = 0b10).

The following example further illustrates the steps required to perform two reads from the RAM array at non-sequential addresses assuming that the relevant BRn and ORn registers have been previously set up:

- 1. Program MxMR for the first read with the desired RAM array address.
- 2. Read MxMR to ensure that the MxMR has already been updated with the desired configuration, such as RAM array address.
- 3. Perform a dummy read transaction.

- 4. Read/check MxMR[MAD]. If incremented, the previous dummy read transaction is completed; proceed to step 5. Repeat step 4 until incremented.
- 5. Read MDR.
- 6. Program MxMR for the second read with the desired RAM array address.
- 7. Read MxMR to ensure that the MxMR has already been updated with the desired configuration, such as RAM array address.
- 8. Perform a dummy read transaction.
- 9. Read/check MxMR[MAD]. If incremented, the previous dummy read transaction is completed; proceed to step 10. Repeat step 9 until incremented.
- 10. Read MDR.

## 12.4.4.3 UPM signal timing

RAM word fields specify the value of the various external signals at a granularity of up to four values for each bus clock cycle.

The signal timing generator causes external signals to behave according to timing specified in the current RAM word. Each bit in the RAM word relating to LCSn\_B and LBS\_B timing specifies the value of the corresponding external signal at each quarter phase of the bus clock.



Figure 12-100. UPM clock scheme for LCRR[CLKDIV] = 4 and higher order ratios (PLL bypass)

## 12.4.4.4 RAM array

The RAM array for each UPM is 64 locations deep and 32 bits wide.

The signals at the bottom of the figure are UPM outputs. The selectedLCS*n*\_B is for the bank that matches the current address. The selected LBS\_B is for the byte lanes read or written by the access.



Figure 12-101. RAM array and signal generation

#### 12.4.4.4.1 RAM words

The RAM word is a 32-bit microinstruction stored in one of 64 locations in the RAM array.

It specifies timing for external signals controlled by the UPM. The CST*n* and BST*n* bits determine the state of UPM signals LCS*n*\_B and LBS\_B[0:1] at each quarter phase of the bus clock.

|           | 0        | 1         | 2        | 3    | 4        | 5        | 6        | 7        | 8   | 9  | 10  | 11 | 12   | 13   | 14   | 15       |
|-----------|----------|-----------|----------|------|----------|----------|----------|----------|-----|----|-----|----|------|------|------|----------|
| R<br>W    | CST<br>1 | CST<br>2  | CST<br>3 | CST4 | BST<br>1 | BST<br>2 | BST<br>3 | BST<br>4 | G0L |    | G0H |    | G1T1 | G1T3 | G2T1 | G2T<br>3 |
| Rese<br>t | All zei  | All zeros |          |      |          |          |          |          |     |    |     |    |      |      |      |          |
|           | 16       | 17        | 18       | 19   | 20       | 21       | 22       | 23       | 24  | 25 | 26  | 27 | 28   | 29   | 30   | 31       |

Table 12-200. RAM word fields

# Table 12-200. RAM word fields (continued)

| R<br>W | G3T<br>1  | G3T<br>3 | 1/   | G4T3/<br>WAEN | G5T<br>1 | G5T<br>3 | REDO | LOO<br>P | EXE<br>N | AMX | NA | UTA | TODT | LAS<br>T |
|--------|-----------|----------|------|---------------|----------|----------|------|----------|----------|-----|----|-----|------|----------|
|        |           |          | DLT3 |               |          |          |      |          |          |     |    |     |      |          |
| Rese   | All zeros |          |      |               |          |          |      |          |          |     |    |     |      |          |
| t      |           |          |      |               |          |          |      |          |          |     |    |     |      |          |

### Table 12-201. RAM word field descriptions

| Bits  | Name | Description                                                                                                                       |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0     | CST1 | Chip select timing 1. Defines the state (0 or 1) of LCSn_B during bus clock quarter phase 1.                                      |
| 1     | CST2 | Chip select timing 2. Defines the state (0 or 1) of LCSn_B during bus clock quarter phase 2.                                      |
| 2     | CST3 | Chip select timing 3. Defines the state (0 or 1) of LCSn_B during bus clock quarter phase 3.                                      |
| 3     | CST4 | Chip select timing 4. Defines the state (0 or 1) of LCSn_B during bus clock quarter phase 4.                                      |
| 4     | BST1 | Byte select timing 1. Defines the state (0 or 1) of LBS_B during bus clock quarter phase 1.                                       |
| 5     | BST2 | Byte select timing 2. Defines the state (0 or 1) of LBS_B during bus clock quarter phase 2.                                       |
| 6     | BST3 | Byte select timing 3. Defines the state (0 or 1) of LBS_B during bus clock quarter phase 3.                                       |
| 7     | BST4 | Byte select timing 4. Defines the state (0 or 1) of LBS_B during bus clock quarter phase 4.                                       |
| 8-9   | G0L  | General purpose line 0 lower. Defines the state of LGPL0 during the bus clock quarter phases 1 and 2 (first half phase).          |
|       |      | 00 Value defined by MxMR[G0CL]                                                                                                    |
|       |      | 01 Reserved                                                                                                                       |
|       |      | 10 0                                                                                                                              |
|       |      | 11 1                                                                                                                              |
| 10-11 | G0H  | General purpose line 0 higher. Defines the state of LGPL0 during the bus clock quarter phases 3 and 4 (second half phase).        |
|       |      | 00 Value defined by MxMR[G0CL]                                                                                                    |
|       |      | 01 Reserved                                                                                                                       |
|       |      | 10 0                                                                                                                              |
|       |      | 11 1                                                                                                                              |
| 12    | G1T1 | General purpose line 1 timing 1. Defines the state (0 or 1) of LGPL1 during bus clock quarter phases 1 and 2 (first half phase).  |
| 13    | G1T3 | General purpose line 1 timing 3. Defines the state (0 or 1) of LGPL1 during bus clock quarter phases 3 and 4 (second half phase)  |
| 14    | G2T1 | General purpose line 2 timing 1. Defines state (0 or 1) of LGPL2 during bus clock quarter phases 1 and 2 (first half phase).      |
| 15    | G2T3 | General purpose line 2 timing 3. Defines the state (0 or 1) of LGPL2 during bus clock quarter phases 3 and 4 (second half phase). |

# Table 12-201. RAM word field descriptions (continued)

| Bits  | Name      | Description                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | G3T1      | General purpose line 3 timing 1. Defines the state (0 or 1) of LGPL3 during bus clock quarter phases 1 and 2 (first half phase).                                                                                                                                                                                                                                     |
| 17    | G3T3      | General purpose line 3 timing 3. Defines the state (0 or 1) of LGPL3 during bus clock quarter phases 3 and 4 (second half phase).                                                                                                                                                                                                                                    |
| 18    | G4T1/DLT3 | General purpose line 4 timing 1/delay time 3. The function of this bit is determined by MxMR[GPL4].                                                                                                                                                                                                                                                                  |
|       |           | If MxMR[GPL4] = 0 and LGPL4/LUPWAIT pin functions as an output (LGPL4), G4T1/DLT3 defines the state (0 or 1) of LGPL4 during bus clock quarter phases 1 and 2 (first half phase).                                                                                                                                                                                    |
|       |           | If MxMR[GPL4] = 1 and LGPL4/LUPWAIT functions as an input (LUPWAIT), if a read burst or single read is executed, G4T1/DLT3 defines the sampling of the data bus as follows:                                                                                                                                                                                          |
|       |           | 0 In the current word, the data bus should be sampled at the start of bus clock quarter phase 1 of the next bus clock cycle.                                                                                                                                                                                                                                         |
|       |           | 1 In the current word, the data bus should be sampled at the start of bus clock quarter phase 3 of the current bus clock cycle.                                                                                                                                                                                                                                      |
| 19    | G4T3/WAEN | General purpose line 4 timing 3/wait enable. Bit function is determined by MxMR[GPL4].                                                                                                                                                                                                                                                                               |
|       |           | If MxMR[GPL4] = 0 and LGPL4/LUPWAIT pin functions as an output (LGPL4), G4T3/WAEN defines the state (0 or 1) of LGPL4 during bus clock quarter phases 3 and 4 (second half phase).                                                                                                                                                                                   |
|       |           | If MxMR[GPL4] = 1 and LGPL4/LUPWAIT functions as an input (LUPWAIT), G4T3/WAEN is used to enable the wait mechanism:                                                                                                                                                                                                                                                 |
|       |           | 0 LUPWAIT detection is disabled.                                                                                                                                                                                                                                                                                                                                     |
|       |           | 1 LUPWAIT is enabled. If LUPWAIT is detected as being asserted, a freeze in the external signals logical values occurs until LUPWAIT is detected as being negated.                                                                                                                                                                                                   |
| 20    | G5T1      | General purpose line 5 timing 1. Defines the state (0 or 1) of LGPL5 during bus clock quarter phases 1 and 2 (first half phase).                                                                                                                                                                                                                                     |
| 21    | G5T3      | General purpose line 5 timing 3. Defines the state (0 or 1) of LGPL5 during bus clock quarter phases 3 and 4 (second half phase).                                                                                                                                                                                                                                    |
| 22-23 | REDO      | Redo current RAM word. Defines the number of times to execute the current RAM word.                                                                                                                                                                                                                                                                                  |
|       |           | 00 Once (normal operation)                                                                                                                                                                                                                                                                                                                                           |
|       |           | 01 Twice                                                                                                                                                                                                                                                                                                                                                             |
|       |           | 10 Three times                                                                                                                                                                                                                                                                                                                                                       |
|       |           | 11 Four times                                                                                                                                                                                                                                                                                                                                                        |
| 24    | LOOP      | Loop start/end. The first RAM word in the RAM array where LOOP is 1 is recognized as the loop start word. The next RAM word where LOOP is 1 is the loop end word. RAM words between, and including the start and end words, are defined as part of the loop. The number of times the UPM executes this loop is defined in the corresponding loop fields of the MxMR. |
|       |           | 0 The current RAM word is not the loop start word or loop end word.                                                                                                                                                                                                                                                                                                  |
|       |           | 1 The current RAM word is the start or end of a loop.                                                                                                                                                                                                                                                                                                                |
|       |           | NOTE: AMX must not change values in any RAM word which begins a loop                                                                                                                                                                                                                                                                                                 |

Table 12-201. RAM word field descriptions (continued)

| Bits  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25    | EXEN | Exception enable. Allows branching to an exception pattern at the exception start address (EXS). When an internal bus monitor time-out exception is recognized and EXEN in the RAM word is set, the UPM branches to the special exception start address (EXS) and begins operating as the pattern defined there specifies.                                                                                        |
|       |      | The user should provide an exception pattern to negate signals controlled by the UPM in a controlled fashion. For DRAM control, a handler should negate RAS and CAS to prevent data corruption. If EXEN = 0, exceptions are ignored by UPM (but not by local bus) and execution continues. After the UPM branches to the exception start address, it continues reading until the LAST bit is set in the RAM word. |
|       |      | 0 The UPM continues executing the remaining RAM words, ignoring any internal bus monitor time-out.                                                                                                                                                                                                                                                                                                                |
|       |      | 1 The current RAM word allows a branch to the exception pattern after the current cycle if an exception condition is detected.                                                                                                                                                                                                                                                                                    |
| 26-27 | AMX  | Address multiplexing. Determines the source of LAD during an LALE phase. Any change in the AMX field initiates a new LALE (address) phase.                                                                                                                                                                                                                                                                        |
|       |      | 00 LAD (and/or in conjunction with LA) is the non-multiplexed address. For example, column address.                                                                                                                                                                                                                                                                                                               |
|       |      | 01 Reserved                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |      | 10 LAD (and/or in conjunction with LA) is driven with the multiplexed address according to MxMR[AM]. For example, row address. See Address multiplexing (AMX) for more information.                                                                                                                                                                                                                               |
|       |      | 11 LAD (and/or in conjunction with LA) is driven with the contents of MAR. Used, for example, to initialize a mode.                                                                                                                                                                                                                                                                                               |
|       |      | NOTE: Source ID debug mode is only supported for the AMX = 00 setting.  NOTE: AMX must not change values in any RAM word which begins a loop.                                                                                                                                                                                                                                                                     |
| 28    | NA   | Next burst address. Determines when the address is incremented during a burst access.                                                                                                                                                                                                                                                                                                                             |
|       |      | 0 The address increment function is disabled.                                                                                                                                                                                                                                                                                                                                                                     |
|       |      | 1 The address is incremented in the next cycle. In conjunction with the BRn[PS], the increment value of LAn is 1 or 2 for port sizes of 8 and 16 bits, respectively.                                                                                                                                                                                                                                              |
| 29    | UTA  | UPM transfer acknowledge. Indicates assertion of transfer acknowledge in the current cycle.                                                                                                                                                                                                                                                                                                                       |
|       |      | 0 Transfer acknowledge is not asserted in the current cycle.                                                                                                                                                                                                                                                                                                                                                      |
|       |      | 1 Transfer acknowledge is asserted in the current cycle.                                                                                                                                                                                                                                                                                                                                                          |
|       |      | In case of UPM writes, program UTA and LAST in same RAM word.                                                                                                                                                                                                                                                                                                                                                     |
|       |      | In case of UPM reads, program UTA and LAST in consecutive or same RAM words.                                                                                                                                                                                                                                                                                                                                      |

# Table 12-201. RAM word field descriptions (continued)

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | TODT | Turn-on disable timer. The disable timer associated with each UPM allows a minimum time to be guaranteed between two successive accesses to the same memory bank. This feature is critical when DRAM requires a RAS precharge time. TODT turns the timer on to prevent another UPM access to the same bank until the timer expires. The disable timer period is determined in MxMR[DSn]. The disable timer does not affect memory accesses to different banks. Note that TODT must be set together with LAST, otherwise it is ignored. |
|      |      | 0 The disable timer is turned off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      |      | 1 The disable timer for the current bank is activated preventing a new access to the same bank (when controlled by the UPMs) until the disable timer expires. For example, precharge time.                                                                                                                                                                                                                                                                                                                                             |
| 31   | LAST | Last word. When LAST is read in a RAM word, the current UPM pattern terminates and control signal timing set in the RAM word is applied to the current (and last) cycle. However, if the disable timer is activated and the next access is to the same bank, execution of the next UPM pattern is held off and the control signal values specified in the last word are extended in duration for the number of clock cycles specified in MxMR[DSn].                                                                                    |
|      |      | Note that UPM continue to execute RAM words until it finds LAST, irrespective of the assigned region for various patterns like RSS.                                                                                                                                                                                                                                                                                                                                                                                                    |
|      |      | 0 The UPM continues executing RAM words.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |      | 1 Indicates the last RAM word in the program. The service to the UPM request is done after this cycle concludes.                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |      | In case of UPM writes, program UTA and LAST in same RAM word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |      | In case of UPM reads, program UTA and LAST in consecutive or same RAM words.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## 12.4.4.4.2 Chip-select signal timing (CSTn)

If BR*n*[MSEL] of the accessed bank selects a UPM on the currently requested cycle, the UPM manipulates the LCS\_B n for that bank with timing as specified in the UPM RAM word CST*n* fields.

The selected UPM affects only the assertion and negation of the appropriate LCSn\_B signal. The state of the selected LCSn\_B signal of the corresponding bank depends on the value of each CSTn bit.



Figure 12-102. LCSn\_B Signal selection

## 12.4.4.4.3 Byte select signal timing (BSTn)

If BR*n*[MSEL] of the accessed memory bank selects a UPM on the currently requested cycle, the selected UPM affects the assertion and negation of the appropriate LBS\_B[0:1] signal.

The timing of both byte-select signals is specified in the RAM word. However, LBS\_B[0:1] are also controlled by the port size of the accessed bank, the number of bytes to transfer, and the address accessed.



Figure 12-103. LBS\_B Signal selection

The uppermost byte select (LBS0\_B), when asserted, indicates that LAD[0:7] contains valid data during a cycle. Likewise, LBS1\_B indicates that LAD[8:15] contain valid data. For a UPM refresh timer request, all LBS\_B[0:1] signals are asserted/negated by the UPM according to the refresh pattern only. Following any internal bus monitor exception, the LBS\_B [0:1] signals are negated regardless of the exception handling provided by any UPM exception pattern to prevent spurious writes to external RAM.

## 12.4.4.4.4 General-purpose signals (GnTn, GOn)

The general-purpose signals (LGPL[0:5]) each have two bits in the RAM word that define the logical value of the signal to be changed at the rising edge of the bus clock and/or at the falling edge of the bus clock.

LGPL0 offers enhancements beyond the other LGPLn lines.

LGPL0 can be controlled by an address line specified in MxMR[G0CL]. To use this feature, G0H and G0L should be set in the RAM word. For example, for a SIMM with multiple banks, this address line can be used to switch between internal memory device banks.

## **12.4.4.4.5** Loop control (LOOP)

The LOOP bit in the RAM word specifies the beginning and end of a set of UPM RAM words that are to be repeated.

The first time LOOP = 1, the memory controller recognizes it as a loop start word and loads the memory loop counter with the corresponding contents of the loop field shown in the table below. The next RAM word for which LOOP = 1 is recognized as a loop end word. When it is reached, the loop counter is decremented by one.

Continued loop execution depends on the loop counter. If the counter is not zero, the next RAM word executed is the loop start word. Otherwise, the next RAM word executed is the one after the loop end word. Loops can be executed sequentially but cannot be nested. Also, special care must be taken:

- LAST and LOOP must not be set together.
- Loop start word should not have an AMX change with regard to the previous word.

| Request Serviced        | Loop Field |
|-------------------------|------------|
| Read single-beat cycle  | RLF        |
| Read burst cycle        | RLF        |
| Write single-beat cycle | WLF        |
| Write burst cycle       | WLF        |
| Refresh timer expired   | TLF        |
| RUN command             | RLF        |

Table 12-202. MxMR loop field use

## 12.4.4.4.6 Repeat execution of current RAM word (REDO)

The REDO function is useful for wait-state insertion in a long UPM routine that would otherwise need too many RAM words.

Setting the REDO bits of the RAM word to a nonzero value causes the UPM to reexecute the current RAM word up to three more times, as defined in the REDO field of the current RAM word.

Special care must be taken in the following cases:

- When UTA and REDO are set together, TA is asserted the number of times specified by the REDO function.
- When NA and REDO are set together, the address is incremented the number of times specified by the REDO function.
- When LOOP and REDO are set together, the loop mechanism works as usual and the line is repeated according to the REDO function.
- LAST and REDO must not be set together.
- REDO should not be used within the exception routine.

#### 12.4.4.4.7 Address multiplexing (AMX)

Address lines can be controlled by the user-provided pattern in the UPM. The address multiplex (AMX) bits in the RAM word can choose between driving the transaction address (AMX = 00), driving it according to the multiplexing specified by the MxMR[AM] field (AMX = 10), or driving the contents of MAR (AMX = 11) on the address signals. The next address (NA) bit of the RAM word does not affect LA signals, unless AMX = 00 and chooses the column address for NA = 1.

In all cases, LA[27:31] of the eLBC are driven by the five lsbs of the address selected by AMX, regardless of whether the next address (NA) bit of the RAM word is used to increment the current address. The effect of NA = 1 is visible only when AMX = 00 chooses the column address.

Table 12-203 shows how the RAM word AMX bits and MxMR[AM] settings can be used to affect row x column address multiplexing on the LA [16:31] signals. When AMX = 10, LAD[0:15] are driven low during an address phase.

**Internal Transaction Address** msb s b AMX = 10MxMR[AM] = 000(Row) AMX = 00(Col) AMX = 10MxMR[AM] = 001(Row) AMX = 002 2 n (Col) AMX = 10MxMR[AM] = 010(Row) AMX = 00(Col) AMX = 10MxMR[AM] = 011(Row)

Table 12-203. UPM address multiplexing

Table 12-203. UPM address multiplexing (continued)

|                | msb   |     |   | Internal Transaction Address |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
|----------------|-------|-----|---|------------------------------|---|---|---|---|---|---|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|--------|--------|--------|--------|--------|--------|--------|--------|
|                |       |     |   | S                            |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
|                | 0     | 1   | 2 | 3                            | 4 | 5 | 6 | 7 | 8 | 9 | 1<br>0 | 1<br>1 | 1<br>2 | 1 3    | 1<br>4 | 1<br>5 | 1<br>6 | 1<br>7 | 1<br>8 | 1<br>9 | 2<br>0 | 2<br>1 | 2<br>2 | 2 | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2<br>8 | 2<br>9 | 3<br>0 | 3<br>1 |
| AMX = 00       |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        | 2      | 2      | 2 | 2      | 2      | 2      | 2<br>7 | 2      | 2      | 3      | 3      |
| (Col)          |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        | 1      | 2      | 3 | 4      | 5      | 6      | 7      | 8      | 9      | 0      | 1      |
| AMX = 10       |       |     |   |                              | 1 | 1 | 1 | 1 | 2 | 2 | 2      | 2      | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2      | 2      | 3      | 3      |        |        |        |   |        |        |        |        |        |        |        |        |
| MxMR[AM] = 100 |       |     |   |                              | 6 | 7 | 8 | 9 | 0 | 1 | 2      | 3      | 4      | 5      | 6      | 7      | 8      | 9      | 0      | 1      |        |        |        |   |        |        |        |        |        |        |        |        |
| (Row)          |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
| AMX = 00       |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        | 2      | 2      | 2<br>2 | 2 | 2      | 2      | 2      | 2<br>7 | 2<br>8 | 2<br>9 | 3      | 3      |
| (Col)          |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        | 0      | 1      | 2      | 3 | 4      | 5      | 6      | 7      | 8      | 9      | 0      | 1      |
| AMX = 10       |       |     |   | 1                            | 1 | 1 | 1 | 2 | 2 | 2 | 2      | 2<br>4 | 2<br>5 | 2<br>6 | 2<br>7 | 2      | 2      | 3      | 3      |        |        |        |        |   |        |        |        |        |        |        |        |        |
| MxMR[AM] = 101 |       |     |   | 6                            | 7 | 8 | 9 | 0 | 1 | 2 | 3      | 4      | 5      | 6      | 7      | 8      | 9      | 0      | 1      |        |        |        |        |   |        |        |        |        |        |        |        |        |
| (Row)          |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
| AMX = 00       |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        | 1      | 2      | 2      | 2      | 2 | 2      | 2      | 2<br>6 | 2<br>7 | 2<br>8 | 2<br>9 | 3      | 3      |
| (Col)          |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        | 9      | 0      | 1      | 2      | 3 | 4      | 5      | 6      | 7      | 8      | 9      | 0      | 1      |
| AMX = 10       | Reser | vec | t |                              | _ |   |   |   |   |   |        |        | •      |        | •      |        |        |        |        |        |        |        |        |   |        |        |        | •      |        | •      |        |        |
| MxMR[AM] = 110 |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
| AMX = 10       | Reser | vec | k |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |
| MxMR[AM] = 111 |       |     |   |                              |   |   |   |   |   |   |        |        |        |        |        |        |        |        |        |        |        |        |        |   |        |        |        |        |        |        |        |        |

Note that any change to the AMX field from one RAM word to the next RAM word executed results in an address phase on the  $\{LADn, LAn\}$  bus with the assertion of LALE for the number of cycles set for LALE in the ORn and LCRR registers. The LGPL[0:5] signals maintain the value specified in the RAM word during the LALE phase.

#### NOTE

AMX must not change values in any RAM word which begins a loop.

#### 12.4.4.4.8 Data valid and data sample control (UTA)

When a read access is handled by the UPM, and the UTA bit is 1 (data is to be sampled by the eLBC), the value of the DLT3 bit in the same RAM word, in conjunction with MxMR[GPL4], determines when the data input is sampled by the eLBC as follows:

• If MxMR[GPL4] = 1 (G4T4/DLT3 functions as DLT3) and DLT3 = 1 in the RAM word, data is latched on the falling edge of the bus clock instead of the rising edge. The eLBC samples the data on the next falling edge of the bus clock, which is during

- the middle of the current bus cycle. This feature should be used only in systems without external synchronous bus devices that require mid-cycle sampling.
- If MxMR[GPL4] = 0 (G4T4/DLT3 functions as G4T4), or if MxMR[GPL4] = 1 but DLT3 = 0 in the RAM word, data is latched on the rising edge of the bus clock, which occurs at the end of the current bus clock cycle (normal operation).



Figure 12-104. UPM read access data sampling

#### **12.4.4.4.9 LGPL**[0:5] signal negation (LAST)

When the LAST bit is read in a RAM word, the current UPM pattern is terminated at the end of the current cycle.

On the next cycle (following LAST) all the UPM signals are negated unconditionally (driven to logic 1), unless there is a back-to-back UPM request pending. In this case, the signal values for the cycle following the one in which the LAST bit was set are taken from the first RAM word of the pending UPM routine.

In case of UPM writes, program UTA and LAST in same RAM word. In case of UPM reads, program UTA and LAST in consecutive or same RAM words.

#### **12.4.4.4.10** Wait mechanism (WAEN)

The WAEN bit in the RAM array word can be used to enable the UPM wait mechanism in selected UPM RAM words.

If the UPM reads a RAM word with WAEN set, the external LUPWAIT signal is sampled and synchronized by the memory controller as if it were an asynchronous signal. The WAEN bit is ignored if LAST = 1 in the same RAM word.

#### eLBC functional description

Synchronization of LUPWAIT starts at the falling edge of the LCLK and takes at least 1 LCLK cycle to get affected. If LUPWAIT is asserted and WAEN = 1 in the current UPM word, the UPM is frozen until LUPWAIT is negated. The value of external signals driven by the UPM remains as indicated in the previous RAM word. When LUPWAIT is negated, the UPM continues normal functions. Note that during WAIT cycles, the UPM does not handle data.

The figure below shows how the WAEN bit in the word read by the UPM and the LUPWAIT signal are used to hold the UPM in a particular state until LUPWAIT is negated. As the example shows, the LCS $n_B$  and LGPL1 states and the WAEN value are frozen until LUPWAIT is recognized as negated. WAEN is typically set before the line that contains UTA = 1. Note that if WAEN and NA are both set in the same RAM word, NA causes the burst address to increment once as normal regardless of whether the UPM freezes.



Figure 12-105. Effect of LUPWAIT signal with PLL bypass

If LUPWAIT is to be considered an asynchronous signal, which can be asserted/negated at any time, no UPM RAM word must contain both WAEN = 1 and UTA = 1 simultaneously.

#### 12.4.4.5 Extended hold time on read accesses-UPM

Slow memory devices that take a long time to turn off their data bus drivers on read accesses should choose some non-zero combination of ORn[TRLX] and ORn[EHTR].

The next accesses after a read access to the slow memory device is delayed by the number of clock cycles specified in the ORn register in addition to any existing bus turnaround cycle.

## 12.5 eLBC initialization/application information

This section provides information about the following:

- Interfacing to peripherals in different address modes
- Bus turnaround
- Interface to different port-size devices
- Command sequence examples for NAND flash EEPROM
- Interfacing to fast-page mode DRAM using UPM
- Interfacing to ZBT SRAM using UPM

### 12.5.1 Interfacing to peripherals in different address modes

This section provides guidelines for interfacing to peripherals.

#### 12.5.1.1 Non-multiplexed address and data buses

For small address space applications the address latch may be eliminated entirely if the local bus address is taken entirely from LA[16:31], in which case addresses driven onto LAD during address phases are simply ignored. The connection is illustrated in the figure below. In non-multiplexed mode, the waveforms remain the same except for a few things, such as ASHIFT parameter, LAD bus turnaround time, LALE timings, that can be ignored.

#### eLBC initialization/application information



Figure 12-106. Non-multiplexed address and data buses

## 12.5.1.2 Multiplexed address and data to save maximum pins in 8- to 16-bit addressing

With the use of a feature called address byte swap by setting LBCR[ABSWP], data and address muxing can be swapped from the default available.

By default when ABSWAP=0, during the address phase, LAD[0:15] carries the address A[0:15]. When ABSWAP is set to 1 during the address phase, LAD[0:7] carries the address A[24:31], and LAD[8:15] carries the address A[16:23]. The benefit of this feature is that LAD[0:15] carries the useful least significant address information during the address phase. The drawback of this feature is that it does not support burst as all the address is latched from LAD bus.

#### 12.5.1.3 Peripheral hierarchy on the local bus for high bus speeds

To achieve the highest possible bus speeds on the local bus, it is recommended to reduce the number of devices connected directly to the bus.

For best results, only one bank of synchronous SRAMs should have a direct connection, and a bus demultiplexor should be used to replace separate latch and separate bus transceiver combinations. The figure below shows an example of such a hierarchy. This section is only a guideline, and the board designer must simulate the electric characteristics of the scenario to determine the maximum operating frequency.



Figure 12-107. Local bus peripheral hierarchy for high bus speeds

#### **12.5.1.4 GPCM timings**

In case a system contains a memory hierarchy with high speed synchronous memories (synchronous SRAM) and lower speed asynchronous memories (for example, FLASH EPROM and peripherals) the GPCM-controlled memories should be decoupled by buffers to reduce capacitive loading on the bus.

Those buffers have to be taken into account for the timing calculations.



Figure 12-108. GPCM address timings

To calculate address setup timing for a slower peripheral/memory device, several parameters have to be added: propagation delay for the address latch, propagation delay for the buffer and the address setup for the actual peripheral. Typical values for the two propagation delays are in the order of 3 to 6 ns, so for a 100-MHz bus frequency, LCS\_B should arrive on the order of 2 to 3 bus clocks later.

For data timings, only the propagation delay of one buffer plus the actual data setup time has to be considered.



Figure 12-109. GPCM data timings

#### 12.5.2 Bus turnaround

Because the local bus uses multiplexed address and data, special consideration must be given to avoid bus contention at bus turnaround.

The following cases must be examined:

- Address phase after previous read
- Read data phase after address phase
- Read-modify-write cycle for parity protected memory banks
- UPM cycles with additional address phases

The bus does not change direction for the following cases so they need no special attention:

- Continued burst after the first beat
- Write data phase after address phase
- Address phase after previous write

#### 12.5.2.1 Address phase after previous read

During a read cycle, the memory/peripheral drives the bus and the bus transceiver drives LAD.

After the data has been sampled, the output drivers of the external device must be disabled. This can take some time; for slow devices the EHTR feature of the GPCM or the programmability of the UPM should be used to guarantee that those devices have stopped driving the bus when the eLBC memory controller ends the bus cycle.

In this case, after the previous cycle ends, LBCTL goes high and changes the direction of the bus transceiver. The eLBC then inserts a bus turnaround cycle to avoid contention. The external device has now already placed its data signals in high impedance and no bus contention will occur.

#### 12.5.2.2 Read data phase after address phase

During the address phase, LAD actively drives the address and LBCTL is high, driving the bus transceivers in the same direction as during a write.

After the end of the address phase, LBCTL goes low and changes the direction of the bus transceiver. The eLBC places the LAD signals in high impedance after its  $t_{\rm dis}(LB)$ . The LBCTL will have its new state after  $t_{\rm en}(LB)$  and, because this is an asynchronous input, the transceiver starts to drive those signals after its  $t_{\rm en}(transceiver)$  time. The system designer has to ensure, that  $[t_{\rm en}(LB) + t_{\rm en}(transceiver)]$  is larger than  $t_{\rm dis}(LB)$  to avoid bus contention.

#### 12.5.2.3 Read-modify-write cycle for parity protected memory banks

Principally, a read-modify-write cycle is a read cycle immediately followed by a write cycle.

Because the write cycle will have a new address phase in any case, this basically is the same case as an address phase after a previous read.

#### 12.5.2.4 UPM cycles with additional address phases

The flexibility of the UPM allows the user to insert additional address phases during read cycles by changing the AMX field, therefore turning around the bus during one pattern.

The eLBC automatically inserts a single bus turnaround cycle if the bus (LAD) was previously high impedance for any reason, such as a read, before LALE is driven and LAD is driven with the new address. The turnaround cycle is not inserted on a write, because the bus was already driven to begin with.

However, bus contention could potentially still occur on the far side of a bus transceiver. It is the responsibility of the designer of the UPM pattern to guarantee that enough idle cycles are inserted in the UPM pattern to avoid this.

#### 12.5.3 Interface to different port-size devices

The eLBC supports 8- and 16-bit data port sizes.

However, the bus requires that the portion of the data bus used for a transfer to or from a particular port size be fixed. A 16-bit port must reside on LAD[0-15], and an 8-bit port must reside on LAD[0-7]. The local bus always tries to transfer the maximum amount of data on all bus cycles



Figure 12-110. Interface to different port-size devices

Table 12-204. Data bus drive requirements for read cycles

| Transfer  | Address |     | Port Size/LAD Data Bus Assignments |       |       |     |      |       |       |  |  |  |  |  |  |
|-----------|---------|-----|------------------------------------|-------|-------|-----|------|-------|-------|--|--|--|--|--|--|
| Size      | State 1 |     | 16                                 | -Bit  |       |     | 8-   | Bit   |       |  |  |  |  |  |  |
|           | 3 Isbs  | 0-7 | 8-15                               | 16-23 | 24-31 | 0-7 | 8-15 | 16-23 | 24-31 |  |  |  |  |  |  |
| Byte      | 000     | OP0 | -                                  |       |       | OP0 |      |       |       |  |  |  |  |  |  |
|           | 001     | -   | OP1                                |       |       | OP1 |      |       |       |  |  |  |  |  |  |
|           | 010     | OP2 | -                                  |       |       | OP2 |      |       |       |  |  |  |  |  |  |
|           | 011     | -   | OP3                                |       |       | OP3 |      |       |       |  |  |  |  |  |  |
|           | 100     | OP4 | -                                  |       |       | OP4 |      |       |       |  |  |  |  |  |  |
|           | 101     | -   | OP5                                |       |       | OP5 |      |       |       |  |  |  |  |  |  |
|           | 110     | OP6 | -                                  |       |       | OP6 |      |       |       |  |  |  |  |  |  |
|           | 111     | -   | OP7                                |       |       | OP7 |      |       |       |  |  |  |  |  |  |
| Half Word | 000     | OP0 | OP1                                |       |       | OP0 |      |       |       |  |  |  |  |  |  |
|           | 001     | -   | OP1                                |       |       | OP1 |      |       |       |  |  |  |  |  |  |
|           | 010     | OP2 | OP3                                |       |       | OP2 |      |       |       |  |  |  |  |  |  |
|           | 100     | OP4 | OP5                                |       |       | OP4 |      |       |       |  |  |  |  |  |  |
|           | 101     | -   | OP5                                |       |       | OP5 |      |       |       |  |  |  |  |  |  |
|           | 110     | OP6 | OP7                                |       |       | OP6 |      |       |       |  |  |  |  |  |  |
| Word      | 000     | OP0 | OP1                                |       |       | OP0 |      |       |       |  |  |  |  |  |  |
|           | 100     | OP4 | OP5                                |       |       | OP4 |      |       |       |  |  |  |  |  |  |

<sup>1.</sup> Address state is the calculated address for port size.

#### 12.5.4 Command sequence examples for NAND flash EEPROM

To program the eLBC and FCM for executing NAND Flash command sequences, command codes and pause states should be obtained from the relevant NAND Flash device data sheet and programmed into FCM configuration registers.

This section illustrates some common sequences for large-page, multi-gigabit NAND Flash EEPROMs; however, details should be verified against manufacturers' specific programming data.

Throughout these examples it is assumed that one or more banks of eLBC has been configured under FCM control (BRn[MSEL] = 001), with base address, port size, ECC mode, and timing parameters configured in accordance with the chip hardware specifications.

#### 12.5.4.1 NAND flash soft reset command sequence example

An example of configuring FCM to execute a soft reset command to large-page NAND Flash is shown in the table below.

This sequence does not require use of the shared FCM buffer RAM.

The sequence is initiated by writing FMR[OP] = 10, and issuing a special operation to the bank. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled.

Table 12-205. FCM register settings for soft reset (ORn[PGS] = 1)

| Register | Initial Contents | Description                                        |
|----------|------------------|----------------------------------------------------|
| FCR      | 0xFF00_0000      | CMD0 = 0xFF = reset command; other commands unused |
| FBAR     | -                | Unused                                             |
| FPAR     | -                | Unused                                             |
| FBCR     | -                | Unused                                             |
| MDR      | -                | Unused                                             |
| FIR      | 0x4000_0000      | OP0 = CM0 = command 0;                             |
|          |                  | OP1-OP7 = NOP                                      |

#### 12.5.4.2 NAND flash read status command sequence example

An example of configuring FCM to execute a status read command to large-page NAND Flash is shown in the table below.

This sequence does not require use of the shared FCM buffer RAM, but reads the NAND Flash status into register MDR[AS0].

The sequence is initiated by writing FMR[OP] = 10 and issuing a special operation to the bank. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled.

Table 12-206. FCM register settings for status read (ORn[PGS] = 1)

| Register | Initial Contents | Description                                              |
|----------|------------------|----------------------------------------------------------|
| FCR      | 0x7000_0000      | CMD0 = 0x70 = read status command; other commands unused |
| FBAR     | -                | Unused                                                   |
| FPAR     | -                | Unused                                                   |
| FBCR     | -                | Unused                                                   |
| MDR      | -                | Status returned in AS0                                   |

Table 12-206. FCM register settings for status read (ORn[PGS] = 1) (continued)

| Register | Initial Contents | Description                    |  |  |  |  |  |
|----------|------------------|--------------------------------|--|--|--|--|--|
| FIR      | 0x4B00_0000      | OP0 = CM0 = command 0;         |  |  |  |  |  |
|          |                  | OP1 = RS = read status to MDR; |  |  |  |  |  |
|          |                  | OP2-OP7 = NOP                  |  |  |  |  |  |

#### 12.5.4.3 NAND flash read identification command sequence example

An example of configuring FCM to execute a status ID command to large-page NAND Flash is shown in the table below.

This sequence does not require use of the shared FCM buffer RAM, but uses MDR to set up a dummy address prior to the sequence, and then to receive the first 4 bytes of ID during the sequence.

The sequence is initiated by writing FMR[OP] = 10, and issuing a special operation to the bank. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled. MDR[AS3-AS0] then can be read to obtain the first 4 bytes of NAND Flash ID.

Table 12-207. FCM register settings for ID read (ORn[PGS] = 1)

| Register | Initial Contents | Description                                          |
|----------|------------------|------------------------------------------------------|
| FCR      | 0x9000_0000      | CMD0 = 0x90 = read ID command; other commands unused |
| FBAR     | -                | Unused                                               |
| FPAR     | -                | Unused                                               |
| FBCR     | -                | Unused                                               |
| MDR      | All zeros        | AS0 = 0x00 = dummy address for read ID command;      |
|          |                  | AS0-AS3 return with first 4 bytes of ID code         |
| FIR      | 0x43BB_BBB0      | OP0 = CM0 = command 0;                               |
|          |                  | OP1 = UA = user address from MDR;                    |
|          |                  | OP2-OP6 = RS = read 4 bytes ID into MDR[AS3-AS0];    |
|          |                  | OP7 = NOP                                            |
| FMR      | 0x0000_F002      |                                                      |
| LSOR     | 0x0000_0001      | Assumes NAND flash is on eLBC CS1                    |

#### 12.5.4.4 NAND flash page read command sequence example

An example of configuring FCM to execute a random page read command to large-page NAND Flash is shown in the table below.

This sequence reads an entire page (main and spare region) into the shared FCM buffer RAM, checking ECC as it proceeds.

The sequence is initiated by writing FMR[OP] = 11, and issuing a special operation to the bank. A few cycles before completion itself, FECCn gets updated with the ECC bytes for the main region validated by FECCn[0]. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled. Once the sequence has completed, the shared buffer (buffer 1 for page index 5) and transfer error registers (LTECCR that reports the 512 blocks with unibit /multibit errors if any) are valid.

| Register | Initial Contents                      | Description                                                    |  |  |  |  |  |
|----------|---------------------------------------|----------------------------------------------------------------|--|--|--|--|--|
| FCR      | 0x0030_0000                           | CMD0 = 0x00 = random read address entry;                       |  |  |  |  |  |
|          |                                       | CMD1 = 0x30 = read page                                        |  |  |  |  |  |
| FBAR     | block index                           | BLK locates index of 128-Kbyte block                           |  |  |  |  |  |
|          | (for example block 0x0001_0AB4)       |                                                                |  |  |  |  |  |
| FPAR     | page offset                           | PI locates page index in BLK;                                  |  |  |  |  |  |
|          | (for example 0x0000_5000 locates page | e PI mod 2 indexes FCM buffer RAM;                             |  |  |  |  |  |
|          | 5, buffer 1)                          | MS = 0 and CI = 0                                              |  |  |  |  |  |
| FBCR     | All zeros                             | BC = 0 to read entire 2112-byte page with ECC check            |  |  |  |  |  |
| MDR      | -                                     | Unused                                                         |  |  |  |  |  |
| FIR      | 0x4125_E000                           | OP0 = CM0 = command 0;                                         |  |  |  |  |  |
|          |                                       | OP1 = CA = column address;                                     |  |  |  |  |  |
|          |                                       | OP2 = PA = page address;                                       |  |  |  |  |  |
|          |                                       | OP3 = CM1 = command 1;                                         |  |  |  |  |  |
|          |                                       | OP4 = RBW = wait on Flash ready and read data into FCM buffer; |  |  |  |  |  |
|          |                                       | OP5-OP7 = NOP                                                  |  |  |  |  |  |

Table 12-208. FCM register settings for page read (ORn[PGS] = 1)

#### 12.5.4.5 NAND flash block erase command sequence example

An example of configuring FCM to execute a block erase command to large-page NAND Flash is shown in the table below.

This sequence does not require use of the shared FCM buffer RAM, but returns with the erase status in MDR[AS0].

The sequence is initiated by writing FMR[OP] = 11, and issuing a special operation to the bank. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled.

Note that operations specified by OP3 and OP4 (status read) should never be skipped while erasing a NAND Flash device, because, in case that happens, contention may arise on LGPL4. A possible case is that the next transaction from eLBC may try to use that pin as an output and since the NAND Flash device might already be driving it, contention will occur. In case OP3 and OP4 operations are skipped, it may also happen that a new command is issued to the NAND Flash device even when the device has not yet finished processing the previous request. This may also result in unpredictable behavior.

Register **Initial Contents Description FCR** 0x6070\_D000 CMD0 = 0x60 = block address entry;CMD1 = 0x70 = read statusCMD2 = 0xD0 = erase block;**FBAR Block Index** BLK locates index of 128-Kbyte block (for example block 0x0001\_0AB4) **FPAR** All zeros PI = 0 to locate block boundary **FBCR** Unused MDR Returns with AS0 holding erase status FIR 0x426D\_B000 OP0 = CM0 = command 0;OP1 = PA = page address; OP2 = CM2 = command 2;OP3 = CW1 = wait on Flash ready and issue command 1; OP4 = RS = read erase status into MDR[AS0]; OP5-OP7 = NOP

Table 12-209. FCM register settings for block erase (ORn[PGS] = 1)

#### 12.5.4.6 NAND flash program command sequence example

An example of configuring FCM to execute a program command to large-page NAND Flash is shown in the table below.

This sequence writes an entire page (main and spare region) from the shared FCM buffer RAM, generating ECC as it proceeds.

#### eLBC initialization/application information

The shared buffer (buffer 1 for page index 5) must be initialized by software prior to starting the sequence. The sequence is initiated by writing FMR[OP] = 11, and issuing a special operation to the bank. At the conclusion of the sequence, eLBC will issue a command complete interrupt (LTESR[CC]) if interrupts are enabled. The status of the programming operation is returned in MDR[AS0].

Note that operations specified by OP5 and OP6 (status read) should never be skipped while programming a NAND Flash device, because, in case that happens, contention may arise on LGPL4. A possible case is that the next transaction from eLBC may try to use that pin as an output and since the NAND Flash device might already be driving it, contention will occur. In case OP5 and OP6 operations are skipped, it may also happen that a new command is issued to the NAND Flash device even when the device has not yet finished processing the previous request. This may also result in unpredictable behavior.

Table 12-210. FCM register settings for page program (ORn[PGS] = 1)

| Register | Initial Contents                      | Description                                               |  |  |
|----------|---------------------------------------|-----------------------------------------------------------|--|--|
| FCR      | 0x8070_1000                           | CMD0 = 0x80 = page address and data entry;                |  |  |
|          |                                       | CMD1 = 0x70 = read status                                 |  |  |
|          |                                       | CMD2 = 0x10 = program page;                               |  |  |
| FBAR     | block index                           | BLK locates index of 128-Kbyte block                      |  |  |
|          | (for example block 0x0001_0AB4)       |                                                           |  |  |
| FPAR     | page offset                           | PI locates page index in BLK;                             |  |  |
|          | (for example 0x0000_5000 locates page | PI mod 2 indexes FCM buffer RAM;                          |  |  |
|          | 5, buffer 1)                          | MS = 0 and CI = 0                                         |  |  |
| FBCR     | All zeros                             | BC = 0 to write entire 2112-Byte page with ECC generation |  |  |
| MDR      | -                                     | Returns with AS0 holding program status                   |  |  |
| FIR      | 0x4128_6DB0                           | OP0 = CM0 = command 0;                                    |  |  |
|          |                                       | OP1 = CA = column address;                                |  |  |
|          |                                       | OP2 = PA = page address;                                  |  |  |
|          |                                       | OP3 = WB = write data from buffer;                        |  |  |
|          |                                       | OP4 = CM2 = command 2;                                    |  |  |
|          |                                       | OP5 = CW1 = wait on Flash ready and issue command 1;      |  |  |
|          |                                       | OP6 = RS = read erase status into MDR[AS0];               |  |  |
|          |                                       | OP7 = NOP                                                 |  |  |

#### 12.5.5 Interfacing to fast-page mode DRAM using UPM

Connecting the local bus UPM controller to a DRAM device requires a detailed examination of the timing diagrams representing the possible memory cycles that must be performed when accessing this device.

This section describes timing diagrams for various UPM configurations for fast-page mode DRAM, with LCRR[CLKDIV] = 4 (clock ratio of 8) or 8 (clock ratio of 16). The illustrative examples shown in Table 12-211-Table 12-215 may not represent the timing necessary for any specific device used with the eLBC. Here, LGPL1 is programmed to drive R/W of the DRAM, although any LGPLn signal may be used for this purpose.



Figure 12-111. Single-beat read access to FPM DRAM

Table 12-211. Single-beat read access to FPM DRAM

| cst1    | 0   | LALE pause (due   | 0       | 0       | Bit 0  |
|---------|-----|-------------------|---------|---------|--------|
| cst2    | 0   | to change in AMX) | 0       | 0       | Bit 1  |
| cst3    | 0   |                   | 0       | 0       | Bit 2  |
| cst4    | 0   |                   | 0       | 0       | Bit 3  |
| bst1    | 1   |                   | 1       | 0       | Bit 4  |
| bst2    | 1   |                   | 0       | 0       | Bit 5  |
| bst3    | 1   |                   | 0       | 0       | Bit 6  |
| bst4    | 1   |                   | 0       | 0       | Bit 7  |
| g0l0    |     |                   |         |         | Bit 8  |
| g0l1    |     |                   |         |         | Bit 9  |
| g0h0    |     |                   |         |         | Bit 10 |
| g0h1    |     |                   |         |         | Bit 11 |
| g1t1    | 1   |                   | 1       | 1       | Bit 12 |
| g1t3    | 1   |                   | 1       | 1       | Bit 13 |
| g2t1    |     |                   |         |         | Bit 14 |
| g2t3    |     |                   |         |         | Bit 15 |
| g3t1    |     |                   |         |         | Bit 16 |
| g3t3    |     |                   |         |         | Bit 17 |
| g4t1    |     |                   |         |         | Bit 18 |
| g4t3    |     |                   |         |         | Bit 19 |
| g5t1    |     |                   |         |         | Bit 20 |
| g5t3    |     |                   |         |         | Bit 21 |
| redo[0] |     |                   |         |         | Bit 22 |
| redo[1] |     |                   |         |         | Bit 23 |
| loop    | 0   |                   | 0       | 0       | Bit 24 |
| exen    | 0   |                   | 0       | 0       | Bit 25 |
| amx0    | 1   |                   | 0       | 0       | Bit 26 |
| amx1    | 0   |                   | 0       | 0       | Bit 27 |
| na      | 0   |                   | 0       | 0       | Bit 28 |
| uta     | 0   |                   | 0       | 1       | Bit 29 |
| todt    | 0   |                   | О       | 1       | Bit 30 |
| last    | 0   |                   | 0       | 1       | Bit 31 |
|         | RSS | RSS + 1           | RSS + 1 | RSS + 2 |        |



Figure 12-112. Single-beat write access to FPM DRAM

Table 12-212. Single-beat write access to FPM DRAM

|         | wss | WSS + 1           | WSS + 1 | WSS + 2 |        |
|---------|-----|-------------------|---------|---------|--------|
| last    | 0   |                   | 0       | 1       | Bit 31 |
| todt    | 0   |                   | 0       | 1       | Bit 30 |
| uta     | 0   |                   | 0       | 1       | Bit 29 |
| na      | 0   |                   | 0       | 0       | Bit 28 |
| amx1    | 0   |                   | 0       | 0       | Bit 27 |
| amx0    | 1   |                   | 0       | 0       | Bit 26 |
| exen    | 0   |                   | 0       | 0       | Bit 25 |
| loop    | 0   |                   | 0       | 0       | Bit 24 |
| redo[1] |     |                   |         |         | Bit 23 |
| redo[0] |     |                   |         |         | Bit 22 |
| g5t3    |     |                   |         |         | Bit 21 |
| g5t1    |     |                   |         |         | Bit 20 |
| g4t3    |     |                   |         |         | Bit 19 |
| g4t1    |     |                   |         |         | Bit 18 |
| g3t3    |     |                   |         |         | Bit 17 |
| g3t1    |     |                   |         |         | Bit 16 |
| g2t3    |     |                   |         |         | Bit 15 |
| g2t1    |     |                   |         |         | Bit 14 |
| g1t3    | 0   |                   | 0       | 0       | Bit 13 |
| g1t1    | 0   |                   | 0       | 0       | Bit 12 |
| g0h1    |     |                   |         |         | Bit 11 |
| g0h0    |     |                   |         |         | Bit 10 |
| g0l1    |     |                   |         |         | Bit 9  |
| g0l0    |     |                   |         |         | Bit 8  |
| bst4    | 1   |                   | 0       | 1       | Bit 7  |
| bst3    | 1   |                   | 0       | 0       | Bit 6  |
| bst2    | 1   |                   | 1       | 0       | Bit 5  |
| bst1    | 1   |                   | 1       | 0       | Bit 4  |
| cst4    | 0   |                   | 0       | 1       | Bit 3  |
| cst3    | 0   |                   | 0       | 0       | Bit 2  |
| cst2    | 0   | to change in AMX) | 0       | 0       | Bit 1  |
| cst1    | 0   | LALE pause (due   | 0       | 0       | Bit 0  |



Figure 12-113. Burst read access to FPM DRAM using LOOP (two beats shown)

Table 12-213. Burst read access to FPM DRAM using LOOP (two beats shown)

| cst1    | 0   | LALE pause                | 0       | 0       | 1       | Bit 0  |
|---------|-----|---------------------------|---------|---------|---------|--------|
| cst2    | 0   | (due to change<br>in AMX) | 0       | 0       | 1       | Bit 1  |
| cst3    | 0   |                           | 0       | 0       | 1       | Bit 2  |
| cst4    | 0   |                           | 0       | 0       | 1       | Bit 3  |
| bst1    | 1   |                           | 1       | 0       | 1       | Bit 4  |
| bst2    | 1   |                           | 1       | 0       | 1       | Bit 5  |
| bst3    | 1   |                           | 1       | 0       | 1       | Bit 6  |
| bst4    | 1   |                           | 0       | 0       | 1       | Bit 7  |
| g0l0    |     |                           |         |         |         | Bit 8  |
| g0l1    |     |                           |         |         |         | Bit 9  |
| g0h0    |     |                           |         |         |         | Bit 10 |
| g0h1    |     |                           |         |         |         | Bit 11 |
| g1t1    | 1   |                           | 1       | 1       | 1       | Bit 12 |
| g1t3    | 1   |                           | 1       | 1       | 1       | Bit 13 |
| g2t1    |     |                           |         |         |         | Bit 14 |
| g2t3    |     |                           |         |         |         | Bit 15 |
| g3t1    |     |                           |         |         |         | Bit 16 |
| g3t3    |     |                           |         |         |         | Bit 17 |
| g4t1    |     |                           |         |         |         | Bit 18 |
| g4t3    |     |                           |         |         |         | Bit 19 |
| g5t1    |     |                           |         |         |         | Bit 20 |
| g5t3    |     |                           |         |         |         | Bit 21 |
| redo[0] |     |                           |         |         |         | Bit 22 |
| redo[1] |     |                           |         |         |         | Bit 23 |
| Іоор    | 0   |                           | 1       | 1       | 0       | Bit 24 |
| exen    | 0   |                           | 0       | 1       | 0       | Bit 25 |
| amx0    | 1   |                           | 0       | 0       | 0       | Bit 26 |
| amx1    | 0   |                           | 0       | 0       | 0       | Bit 27 |
| na      | 0   |                           | 0       | 1       | 0       | Bit 28 |
| uta     | 0   |                           | 0       | 1       | 0       | Bit 29 |
| todt    | 0   |                           | 0       | 0       | 1       | Bit 30 |
| last    | 0   |                           | 0       | 0       | 1       | Bit 31 |
|         | RBS |                           | RBS + 1 | RBS + 2 | RBS + 3 |        |



Figure 12-114. Refresh cycle (CBR) to FPM DRAM

Table 12-214. Refresh cycle (CBR) to FPM DRAM

| cst1 | 1 | 0 | 0 | Bit 0  |
|------|---|---|---|--------|
| cst2 | 1 | 0 | 0 | Bit 1  |
| cst3 | 1 | 0 | 1 | Bit 2  |
| cst4 | 1 | 0 | 1 | Bit 3  |
| bst1 | 1 | 0 | 0 | Bit 4  |
| bst2 | 0 | 0 | 0 | Bit 5  |
| bst3 | 0 | 0 | 1 | Bit 6  |
| bst4 | 0 | 0 | 1 | Bit 7  |
| g0l0 |   |   |   | Bit 8  |
| g0l1 |   |   |   | Bit 9  |
| g0h0 |   |   |   | Bit 10 |
| g0h1 |   |   |   | Bit 11 |
| g1t1 |   |   |   | Bit 12 |
| g1t3 |   |   |   | Bit 13 |
| g2t1 |   |   |   | Bit 14 |
| g2t3 |   |   |   | Bit 15 |

Table 12-214. Refresh cycle (CBR) to FPM DRAM (continued)

|         | PTS | PTS + 1 | PTS + 2 |        |
|---------|-----|---------|---------|--------|
| last    | 0   | 0       | 1       | Bit 31 |
| todt    | 0   | 0       | 1       | Bit 30 |
| uta     | 0   | 0       | 0       | Bit 29 |
| na      | 0   | 0       | 0       | Bit 28 |
| amx1    | 0   | 0       | 0       | Bit 27 |
| amx0    | 0   | 0       | 0       | Bit 26 |
| exen    | 0   | 0       | 0       | Bit 25 |
| loop    | 0   | 0       | 0       | Bit 24 |
| redo[1] |     |         |         | Bit 23 |
| redo[0] |     |         |         | Bit 22 |
| g5t3    |     |         |         | Bit 21 |
| g5t1    |     |         |         | Bit 20 |
| g4t3    |     |         |         | Bit 19 |
| g4t1    |     |         |         | Bit 18 |
| g3t3    |     |         |         | Bit 17 |
| g3t1    |     |         |         | Bit 16 |



Figure 12-115. Exception cycle

Table 12-215. Exception cycle



#### Table 12-215. Exception cycle (continued)

| cst2    | 1   | Bit 1  |
|---------|-----|--------|
| cst3    | 1   | Bit 2  |
| cst4    | 1   | Bit 3  |
| bst1    | 1   | Bit 4  |
| bst2    | 1   | Bit 5  |
| bst3    | 1   | Bit 6  |
| bst4    | 1   | Bit 7  |
| g0l0    |     | Bit 8  |
| g0l1    |     | Bit 9  |
| g0h0    |     | Bit 10 |
| g0h1    |     | Bit 11 |
| g1t1    |     | Bit 12 |
| g1t3    |     | Bit 13 |
| g2t1    |     | Bit 14 |
| g2t3    |     | Bit 15 |
| g3t1    |     | Bit 16 |
| g3t3    |     | Bit 17 |
| g4t1    |     | Bit 18 |
| g4t3    |     | Bit 19 |
| g5t1    |     | Bit 20 |
| g5t3    |     | Bit 21 |
| redo[0] |     | Bit 22 |
| redo[1] |     | Bit 23 |
| loop    | 0   | Bit 24 |
| exen    | 0   | Bit 25 |
| amx0    | 0   | Bit 26 |
| amx1    | 0   | Bit 27 |
| na      | 0   | Bit 28 |
| uta     | 0   | Bit 29 |
| todt    | 1   | Bit 30 |
| last    | 1   | Bit 31 |
|         | EXS |        |
| I .     |     |        |

## 12.5.6 Interfacing to ZBT SRAM using UPM

ZBT SRAMs have been designed to optimize the performance of table access in networking applications.

#### eLBC initialization/application information

This section describes how to interface to ZBT SRAMs. The figure below shows the connections. The UPM is used to generate control signals. The same interfacing is used for pipelined and flow-through versions of ZBT SRAMs. However different UPM patterns must be generated for those cases. As ZBT SRAMs are mostly used by performance-critical applications, it is assumed here that, typically, the maximum width of the local bus of 16 bits will be used.



Figure 12-116. Interface to ZBT SRAM

ZBT SRAMs allow different configurations. For the local bus, the burst order should be set to linear burst order by tying the mode pin to GND. CKE\_B should also be tied to ground.

ZBT SRAMs perform four-beat bursts. Because the eLBC generates sixteen-beat transactions (for 16-bit ports) the UPM breaks down each burst into four consecutive four-beat bursts. The internal address generator of the eLBC generates the new LA{A27, A28} for the second, third, and fourth burst. In other words, because linear burst is used on the SRAM, the device itself bursts with the burst addresses of [0:1:2:3]. The local bus always generates linear bursts and expects [0:1:2:3:4:5:6:7:...:15]. Therefore, four

consecutive linear bursts of the ZBT SRAM with  $\{A21, A22\} = \{0,0\}$  for the first burst,  $\{A21, A22\} = \{0,1\}$  for the second burst,  $\{A27, A28\} = \{1,0\}$  for the third burst, and  $\{A27, A28\} = \{1,1\}$  for the fourth burst give the desired burst pattern.



# Chapter 13 DMA Controller

The DMA controller transfers blocks of data between the many interface and functional modules of this chip, independent of the core or external hosts.

#### 13.1 DMA overview

This chapter describes the DMA controller offered on this chip.

The DMA controller transfers blocks of data between the many interface and functional modules of this chip, independent of the cores or external hosts. It has four high-speed DMA channels. Both the cores and external devices can initiate DMA transfers. The channels are capable of complex data movement and advanced transaction chaining. Operations such as descriptor fetches and block transfers are initiated by each channel. A channel is selected by the arbitration logic and information is passed to the source and destination control blocks for processing. The source and destination blocks generate read and write requests to the address tenure engine, which manages the DMA master port address interface. After a transaction is accepted by the master port, control is transferred to the data tenure engine that manages the read and write data transfers. A channel remains active in the shared resources for the duration of the data transfer unless the allotted bandwidth per channel is reached.

This figure shows the block diagram of the DMA controller.



Figure 13-1. DMA block diagram

## 13.1.1 DMA features summary

The DMA controller offers the following features:

- Four high-speed/high-bandwidth channels accessible by local and remote masters
- Basic DMA operation modes (direct, simple chaining)
- Extended DMA operation modes (advanced chaining and stride capability)
- Cascading descriptor chains
- Misaligned transfers
- Programmable bandwidth control between channels
- Up to 256 bytes for DMA sub-block transfers to maximize performance
- Three priority levels supported for source and destination transactions
- Interrupt on error and completed segment, list, or link
- Externally-controlled transfer using DMA\_DREQ\_B, DMA\_DACK\_B, and DMA\_DDONE\_B.

#### 13.1.2 DMA modes of operation

The DMA module has two modes of operation: basic and extended.

Basic mode is the DMA legacy mode, which does not support advanced features. Extended mode supports advanced features such as striding and flexible descriptor structures.

These two basic modes allow users to initiate and end DMA transfers in various ways. Table 13-1 summarizes the relationship between the modes and the following features:

- Direct mode-No descriptors are involved. Software must initialize the required fields as described in Table 13-2 before starting a transfer.
- Chaining mode-Software must initialize descriptors in memory and the required fields as described in Table 13-2 before starting a transfer.
- Single-write start mode-The DMA process can be started using a single-write command to either the descriptor address register in one of the chaining modes or the source/destination address registers in one of the direct modes.
- External control capability-This allows an external agent to start, pause, and check the status of a DMA transfer that has already been initialized.
- Channel continue capability-The channel continue capability allows software the flexibility of having the DMA controller start with descriptors that have already been programmed while software continues to build more descriptors in memory.
- Channel abort capability-The software can abort a previously initiated transfer by setting the bit MR*n*[CA]. The DMA controller terminates all outstanding transfers initiated by the channel without generating any errors before entering an idle state.

| Mode           | Mode with one additional feature | Mode with two additional features                    |  |  |  |
|----------------|----------------------------------|------------------------------------------------------|--|--|--|
| B (Basic)      | BD (basic direct)                | BDS (BD single-write start)                          |  |  |  |
|                |                                  | BDE (BD external control)  BCE (BC external control) |  |  |  |
|                | BC (basic chaining)              |                                                      |  |  |  |
|                |                                  | BCS (BC single-write start)                          |  |  |  |
| Ext (Extended) | ExtD (extended direct)           | ExtDS (ExtD single-write start)                      |  |  |  |
|                |                                  | ExtDE (ExtD external control)                        |  |  |  |
|                | ExtC (extended chaining)         | ExtCE (ExtC external control)                        |  |  |  |
|                |                                  | ExtCS (ExtC single-write start)                      |  |  |  |

Table 13-1. Relationship of modes and features

The following table describes bit settings required for each DMA mode of operation.

#### **DMA** overview

Table 13-2. DMA mode bit settings

| Modes with features                  | MRn[XFE]              | MRn[CTM] | MRn[SRW] | MRn[CDSM_SWSM] | MRn[EMS_EN] |  |  |  |
|--------------------------------------|-----------------------|----------|----------|----------------|-------------|--|--|--|
| Basic direct modes                   |                       |          |          |                |             |  |  |  |
| Basic direct                         | 0                     | 1        | 0        | 0              | 0           |  |  |  |
| Basic direct external control        | 0                     | 1        | 0        | 0              | 1           |  |  |  |
| Basic direct single-write start      | 0                     | 1        | 1        | 1 or 0         | 0           |  |  |  |
| Basic chaining modes                 | •                     |          |          |                |             |  |  |  |
| Basic chaining                       | 0                     | 0        | Reserved | 0              | 0           |  |  |  |
| Basic chaining external control      | 0                     | 0        | Reserved | 0              | 1           |  |  |  |
| Basic chaining single-write start    | 0                     | 0        | Reserved | 1              | 0           |  |  |  |
| Extended direct modes                | Extended direct modes |          |          |                |             |  |  |  |
| Extended direct                      | 1                     | 1        | 0        | 0              | 0           |  |  |  |
| Extended direct external control     | 1                     | 1        | 0        | 0              | 1           |  |  |  |
| Extended direct single-write start   | 1                     | 1        | 1        | 1 or 0         | 0           |  |  |  |
| Extended chaining modes              |                       |          |          |                |             |  |  |  |
| Extended chaining                    | 1                     | 0        | Reserved | 0              | 0           |  |  |  |
| Extended chaining external control   | 1                     | 0        | Reserved | 0              | 1           |  |  |  |
| Extended chaining single-write start | 1                     | 0        | Reserved | 1              | 0           |  |  |  |

See DMA functional description for details on these modes.

This figure shows the general DMA operational flow chart.



Figure 13-2. DMA operational flow chart

## 13.2 DMA external signal description

This section describes the external DMA signals.

## 13.2.1 Signal overview

This figure summarizes the DMA controller signals.



Figure 13-3. DMA signal summary

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 13.2.2 DMA signal descriptions

This table describes the external DMA control signals. These signals are only utilized when operating in external master mode.

See External control mode transfer.

Table 13-3. DMA signals-detailed signal descriptions

| Signal      | I<br>/ | Description                                                                                                                                                                                  |                                                                                                                                                                                                                                                                |  |  |  |
|-------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| DMA_DREQ_   | ı      | DMA request. Indicates the start of a DMA transfer or a restart from a paused request. Assertion of DMA_DREQ_B n causes MRn[CS] to be set, thereby activating the corresponding DMA channel. |                                                                                                                                                                                                                                                                |  |  |  |
|             |        | State<br>Meaning                                                                                                                                                                             | Asserted-Assertion of DMA_DREQ_B <i>n</i> while DMA_DACK_B <i>n</i> is negated causes a new transfer to start OR resumes a paused transfer if the EMP_EN bit is set. Assertion while DMA_DACK_B <i>n</i> is asserted results in an illegal condition.          |  |  |  |
|             |        |                                                                                                                                                                                              | Negated-Negation while DMA_DACK_B <i>n</i> is asserted has no effect. Negation before the assertion of DMA_DACK_B <i>n</i> results in an illegal condition.                                                                                                    |  |  |  |
|             |        | Timing                                                                                                                                                                                       | Assertion-Can be asserted asynchronously                                                                                                                                                                                                                       |  |  |  |
|             |        |                                                                                                                                                                                              | Negation- Must remain asserted at least until the assertion of the corresponding DMA_DACK_B                                                                                                                                                                    |  |  |  |
| DMA_DACK_   | 0      | DMA acknowledge. Indicates that a DMA transfer is currently in progress                                                                                                                      |                                                                                                                                                                                                                                                                |  |  |  |
| B <i>n</i>  |        | State<br>Meaning                                                                                                                                                                             | Asserted-Indicates that a DMA transfer is currently in progress. Asserted after the assertion of DMA_DREQ_B <i>n</i> to indicate the start of a transfer                                                                                                       |  |  |  |
|             |        |                                                                                                                                                                                              | Negated-Negated after finishing a complete transfer or after entering a paused state if MRn[EMP_EN] is set                                                                                                                                                     |  |  |  |
|             |        | Timing                                                                                                                                                                                       | Assertion-Asynchronous assertion; asserted for more than three system clocks                                                                                                                                                                                   |  |  |  |
|             |        |                                                                                                                                                                                              | Negation-Asynchronous negation; negated for more than three system clocks                                                                                                                                                                                      |  |  |  |
| DMA_DDONE   | 0      | DMA done. Indicates that a DMA transfer is complete                                                                                                                                          |                                                                                                                                                                                                                                                                |  |  |  |
| _B <i>n</i> |        | State<br>Meaning                                                                                                                                                                             | Asserted-Indicates transfer completion. SRn[CB] is clear. Note, however, that write data may still be queued at the target interface or in the process of transfer on an external interface.                                                                   |  |  |  |
|             |        |                                                                                                                                                                                              | Negated-Indicates that the current transfer is in process                                                                                                                                                                                                      |  |  |  |
|             |        | Timing                                                                                                                                                                                       | Assertion-Always asserts asynchronously after the negation of the final DMA_DACK_B <i>n</i> to indicate completion of a transfer. For a paused transfer, DMA_DDONE_B <i>n</i> is asserted asynchronously after the negation of the final DMA_DACK_B <i>n</i> . |  |  |  |
|             |        |                                                                                                                                                                                              | Negation-Negated asynchronously after the assertion of DMA_DREQ_B <i>n</i> for the next transfer                                                                                                                                                               |  |  |  |

## 13.3 DMA controller memory map

This section provides a detailed description of all accessible DMA memory and registers . The descriptions include individual, bit-level descriptions and reset states of each register. Undefined 4-byte address spaces within the map are reserved.

This table lists the DMA registers and their offsets. Note that the full register address is comprised of the programmable CCSRBAR together with the fixed DMA block base address and offset listed in table below.

#### **DMA** memory map

| Offset address (hex) | Register name                                                        |    | Access | Reset value | Section/<br>page |
|----------------------|----------------------------------------------------------------------|----|--------|-------------|------------------|
| 2_1100               | DMA mode register (DMA_MR0)                                          | 32 | R/W    | 0800_0000h  | 13.3.1/686       |
| 2_1104               | DMA status register (DMA_SR0)                                        | 32 | R/W    | 0000_0000h  | 13.3.2/690       |
| 2_1108               | DMA current link descriptor extended address register (DMA_ECLNDAR0) | 32 | R/W    | 0000_0000h  | 13.3.3/691       |
| 2_110C               | DMA current link descriptor address register (DMA_CLNDAR0)           | 32 | R/W    | 0000_0000h  | 13.3.4/692       |
| 2_1110               | DMA source attributes register (DMA_SATR0)                           | 32 | R/W    | 0000_0000h  | 13.3.5/694       |
| 2_1114               | DMA source address register (DMA_SAR0)                               | 32 | R/W    | 0000_0000h  | 13.3.6/695       |
| 2_1118               | DMA destination attributes register (DMA_DATR0)                      | 32 | R/W    | 0000_0000h  | 13.3.7/695       |
| 2_111C               | DMA destination address register (DMA_DAR0)                          | 32 | R/W    | 0000_0000h  | 13.3.8/696       |
| 2_1120               | DMA byte count register (DMA_BCR0)                                   | 32 | R/W    | 0000_0000h  | 13.3.9/697       |
| 2_1124               | DMA extended next link descriptor address register (DMA_ENLNDAR0)    | 32 | R/W    | 0000_0000h  | 13.3.10/<br>697  |
| 2_1128               | DMA next link descriptor address register (DMA_NLNDAR0)              | 32 | R/W    | 0000_0000h  | 13.3.11/<br>698  |
| 2_1130               | DMA extended current list descriptor address register (DMA_ECLSDAR0) | 32 | R/W    | 0000_0000h  | 13.3.12/<br>699  |
| 2_1134               | DMA current list descriptor address register (DMA_CLSDAR0)           | 32 | R/W    | 0000_0000h  | 13.3.13/<br>700  |
| 2_1138               | DMA extended next list descriptor address register (DMA_ENLSDAR0)    | 32 | R/W    | 0000_0000h  | 13.3.14/<br>701  |
| 2_113C               | DMA next list descriptor address register (DMA_NLSDAR0)              | 32 | R/W    | 0000_0000h  | 13.3.15/<br>701  |
| 2_1140               | DMA source stride register (DMA_SSR0)                                | 32 | R/W    | 0000_0000h  | 13.3.16/<br>702  |
| 2_1144               | DMA destination stride register (DMA_DSR0)                           |    | R/W    | 0000_0000h  | 13.3.17/<br>703  |
| 2_1180               | DMA mode register (DMA_MR1)                                          | 32 | R/W    | 0800_0000h  | 13.3.1/686       |
| 2_1184               | DMA status register (DMA_SR1)                                        | 32 | R/W    | 0000_0000h  | 13.3.2/690       |

## **DMA** memory map (continued)

| Offset address (hex) | Register name                                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|----------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_1188               | DMA current link descriptor extended address register (DMA_ECLNDAR1) | 32                 | R/W    | 0000_0000h  | 13.3.3/691       |
| 2_118C               | DMA current link descriptor address register (DMA_CLNDAR1)           |                    | R/W    | 0000_0000h  | 13.3.4/692       |
| 2_1190               | DMA source attributes register (DMA_SATR1)                           | 32                 | R/W    | 0000_0000h  | 13.3.5/694       |
| 2_1194               | DMA source address register (DMA_SAR1)                               | 32                 | R/W    | 0000_0000h  | 13.3.6/695       |
| 2_1198               | DMA destination attributes register (DMA_DATR1)                      | 32                 | R/W    | 0000_0000h  | 13.3.7/695       |
| 2_119C               | DMA destination address register (DMA_DAR1)                          | 32                 | R/W    | 0000_0000h  | 13.3.8/696       |
| 2_11A0               | DMA byte count register (DMA_BCR1)                                   | 32                 | R/W    | 0000_0000h  | 13.3.9/697       |
| 2_11A4               | DMA extended next link descriptor address register (DMA_ENLNDAR1)    | 32                 | R/W    | 0000_0000h  | 13.3.10/<br>697  |
| 2_11A8               | DMA next link descriptor address register (DMA_NLNDAR1)              | 32                 | R/W    | 0000_0000h  | 13.3.11/<br>698  |
| 2_11B0               | DMA extended current list descriptor address register (DMA_ECLSDAR1) | 32                 | R/W    | 0000_0000h  | 13.3.12/<br>699  |
| 2_11B4               | DMA current list descriptor address register (DMA_CLSDAR1)           |                    | R/W    | 0000_0000h  | 13.3.13/<br>700  |
| 2_11B8               | DMA extended next list descriptor address register (DMA_ENLSDAR1)    |                    | R/W    | 0000_0000h  | 13.3.14/<br>701  |
| 2_11BC               | DMA next list descriptor address register (DMA_NLSDAR1)              | 32                 | R/W    | 0000_0000h  | 13.3.15/<br>701  |
| 2_11C0               | DMA source stride register (DMA_SSR1)                                | 32                 | R/W    | 0000_0000h  | 13.3.16/<br>702  |
| 2_11C4               | DMA destination stride register (DMA_DSR1)                           | 32                 | R/W    | 0000_0000h  | 13.3.17/<br>703  |
| 2_1200               | DMA mode register (DMA_MR2)                                          |                    | R/W    | 0800_0000h  | 13.3.1/686       |
| 2_1204               | DMA status register (DMA_SR2)                                        | 32                 | R/W    | 0000_0000h  | 13.3.2/690       |
| 2_1208               | DMA current link descriptor extended address register (DMA_ECLNDAR2) | 32                 | R/W    | 0000_0000h  | 13.3.3/691       |
| 2_120C               | DMA current link descriptor address register (DMA_CLNDAR2)           | 32                 | R/W    | 0000_0000h  | 13.3.4/692       |
| 2_1210               | DMA source attributes register (DMA_SATR2)                           | 32                 | R/W    | 0000_0000h  | 13.3.5/694       |
| 2_1214               | DMA source address register (DMA_SAR2)                               | 32                 | R/W    | 0000_0000h  | 13.3.6/695       |
| 2_1218               | DMA destination attributes register (DMA_DATR2)                      | 32                 | R/W    | 0000_0000h  | 13.3.7/695       |
| 2_121C               | DMA destination address register (DMA_DAR2)                          | 32                 | R/W    | 0000_0000h  | 13.3.8/696       |
| 2_1220               | DMA byte count register (DMA_BCR2)                                   | 32                 | R/W    | 0000_0000h  | 13.3.9/697       |
| 2_1224               | DMA extended next link descriptor address register (DMA_ENLNDAR2)    | 32                 | R/W    | 0000_0000h  | 13.3.10/<br>697  |
| 2_1228               | DMA next link descriptor address register (DMA_NLNDAR2)              |                    | R/W    | 0000_0000h  | 13.3.11/<br>698  |
| 2_1230               | DMA extended current list descriptor address register (DMA_ECLSDAR2) |                    | R/W    | 0000_0000h  | 13.3.12/<br>699  |

# DMA memory map (continued)

| Offset address (hex) | Register name                                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|----------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_1234               | DMA current list descriptor address register (DMA_CLSDAR2)           | 32                 | R/W    | 0000_0000h  | 13.3.13/<br>700  |
| 2_1238               | DMA extended next list descriptor address register (DMA_ENLSDAR2)    | 32                 | R/W    | 0000_0000h  | 13.3.14/<br>701  |
| 2_123C               | DMA next list descriptor address register (DMA_NLSDAR2)              | 32                 | R/W    | 0000_0000h  | 13.3.15/<br>701  |
| 2_1240               | DMA source stride register (DMA_SSR2)                                | 32                 | R/W    | 0000_0000h  | 13.3.16/<br>702  |
| 2_1244               | DMA destination stride register (DMA_DSR2)                           | 32                 | R/W    | 0000_0000h  | 13.3.17/<br>703  |
| 2_1280               | DMA mode register (DMA_MR3)                                          | 32                 | R/W    | 0800_0000h  | 13.3.1/686       |
| 2_1284               | DMA status register (DMA_SR3)                                        | 32                 | R/W    | 0000_0000h  | 13.3.2/690       |
| 2_1288               | DMA current link descriptor extended address register (DMA_ECLNDAR3) | 32                 | R/W    | 0000_0000h  | 13.3.3/691       |
| 2_128C               | DMA current link descriptor address register (DMA_CLNDAR3)           | 32                 | R/W    | 0000_0000h  | 13.3.4/692       |
| 2_1290               | DMA source attributes register (DMA_SATR3)                           | 32                 | R/W    | 0000_0000h  | 13.3.5/694       |
| 2_1294               | DMA source address register (DMA_SAR3)                               | 32                 | R/W    | 0000_0000h  | 13.3.6/695       |
| 2_1298               | DMA destination attributes register (DMA_DATR3)                      | 32                 | R/W    | 0000_0000h  | 13.3.7/695       |
| 2_129C               | DMA destination address register (DMA_DAR3)                          | 32                 | R/W    | 0000_0000h  | 13.3.8/696       |
| 2_12A0               | DMA byte count register (DMA_BCR3)                                   | 32                 | R/W    | 0000_0000h  | 13.3.9/697       |
| 2_12A4               | DMA extended next link descriptor address register (DMA_ENLNDAR3)    | 32                 | R/W    | 0000_0000h  | 13.3.10/<br>697  |
| 2_12A8               | DMA next link descriptor address register (DMA_NLNDAR3)              | 32                 | R/W    | 0000_0000h  | 13.3.11/<br>698  |
| 2_12B0               | DMA extended current list descriptor address register (DMA_ECLSDAR3) | 32                 | R/W    | 0000_0000h  | 13.3.12/<br>699  |
| 2_12B4               | DMA current list descriptor address register (DMA_CLSDAR3)           | 32                 | R/W    | 0000_0000h  | 13.3.13/<br>700  |
| 2_12B8               | DMA extended next list descriptor address register (DMA_ENLSDAR3)    | 32                 | R/W    | 0000_0000h  | 13.3.14/<br>701  |
| 2_12BC               | DMA next list descriptor address register (DMA_NLSDAR3)              | 32                 | R/W    | 0000_0000h  | 13.3.15/<br>701  |
| 2_12C0               | DMA source stride register (DMA_SSR3)                                | 32                 | R/W    | 0000_0000h  | 13.3.16/<br>702  |
| 2_12C4               | DMA destination stride register (DMA_DSR3)                           | 32                 | R/W    | 0000_0000h  | 13.3.17/<br>703  |
| 2_1300               | DMA general status register (DMA_DGSR)                               | 32                 | R      | 0000_0000h  | 13.3.18/<br>704  |

# 13.3.1 DMA mode register (DMA\_MRn)

The mode register allows software to start a DMA transfer and to control various DMA transfer characteristics.



DMA\_MRn field descriptions

| Field | Description                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3   | This field is reserved.                                                                                                                                                                                                             |
| -     | Reserved                                                                                                                                                                                                                            |
| 4–7   |                                                                                                                                                                                                                                     |
| BWC   | Bandwidth/pause control.                                                                                                                                                                                                            |
|       | If multiple channels are executing transfers concurrently the value of MRn[BWC] determines how many bytes a given channel is allowed to transfer before the DMA engine pauses the current channel and switches to the next channel. |
|       | If only one channel is executing transfers the value of MRn[BWC] dictates how many bytes are allowed to transfer before pausing the channel, after which a new assertion of DREQ resumes channel operation.                         |
|       | 0000 1 byte                                                                                                                                                                                                                         |
|       | 0001 2 bytes                                                                                                                                                                                                                        |
|       | 0010 4 bytes                                                                                                                                                                                                                        |
|       | 0011 8 bytes                                                                                                                                                                                                                        |

# DMA\_MRn field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 0100 16 bytes                                                                                                                                                                                                                                                                                                                                                                           |
|                | 0101 32 bytes                                                                                                                                                                                                                                                                                                                                                                           |
|                | 0110 64 bytes                                                                                                                                                                                                                                                                                                                                                                           |
|                | 0111 128 bytes                                                                                                                                                                                                                                                                                                                                                                          |
|                | 1000 256 bytes<br>1001 512 bytes                                                                                                                                                                                                                                                                                                                                                        |
|                | 1001 512 bytes<br>1010 1024 bytes                                                                                                                                                                                                                                                                                                                                                       |
|                | 1011-1110 Reserved                                                                                                                                                                                                                                                                                                                                                                      |
|                | 1111 Disable bandwidth sharing to allow uninterrupted transfers from each channel.                                                                                                                                                                                                                                                                                                      |
| 8–9            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                        |
| 10<br>EMP_EN   | External master pause enable. Valid only if MRn[EMS_EN] is set.                                                                                                                                                                                                                                                                                                                         |
| LIVII _LIV     | 0 Disable the external master pause feature.                                                                                                                                                                                                                                                                                                                                            |
|                | 1 Enable the external master pause feature. Channel is paused as described by MRn[BWC].                                                                                                                                                                                                                                                                                                 |
| 11–12<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                        |
| 13<br>EMS_EN   | External master start enable. This bit does not apply to single-write start modes (direct or chaining).                                                                                                                                                                                                                                                                                 |
| EWIO_EIV       | 0 Disable the channel from being started by an external DMA start pin.                                                                                                                                                                                                                                                                                                                  |
|                | 1 Enable the channel to be started by an external DMA start pin, which sets MRn[CS].                                                                                                                                                                                                                                                                                                    |
| 14–15<br>DAHTS | Destination address hold transfer size. Indicates the transfer size used for each transaction while MRn[DAHE] is set. The byte count register must be in multiples of the size and the destination address register must be aligned based on the size. The transfer size assigned to MRn[DAHTS] must be equal to or smaller than that assigned to MRn[BWC] to avoid undefined behavior. |
|                | 00 1 byte                                                                                                                                                                                                                                                                                                                                                                               |
|                | 01 2 bytes                                                                                                                                                                                                                                                                                                                                                                              |
|                | 10 4 bytes                                                                                                                                                                                                                                                                                                                                                                              |
|                | 11 8 bytes                                                                                                                                                                                                                                                                                                                                                                              |
| 16–17<br>SAHTS | Source address hold transfer size. Indicates the transfer size used for each transaction while MRn[SAHE] is set. The byte count register must be in multiples of the size and the source address register must be aligned based on the size. The transfer size assigned to MRn[SAHTS] must be equal to or smaller than that assigned to MRn[BWC] to avoid undefined behavior.           |
|                | 00 1 byte                                                                                                                                                                                                                                                                                                                                                                               |
|                | 01 2 bytes                                                                                                                                                                                                                                                                                                                                                                              |
|                | 10 4 bytes                                                                                                                                                                                                                                                                                                                                                                              |
|                | 11 8 bytes                                                                                                                                                                                                                                                                                                                                                                              |
| 18<br>DAHE     | Destination address hold enable                                                                                                                                                                                                                                                                                                                                                         |
|                | 0 Disable destination address hold                                                                                                                                                                                                                                                                                                                                                      |
|                | 1 Enable the DMA controller to hold the destination address of a transfer to the size specified by MRn[DAHTS]. Hardware only supports aligned transfers for this feature.                                                                                                                                                                                                               |
| 19<br>SAHE     | Source address hold enable                                                                                                                                                                                                                                                                                                                                                              |
|                | 0 Disable source address hold                                                                                                                                                                                                                                                                                                                                                           |
|                | 1 Enable the DMA controller to hold the source address of a transfer to the size specified by MRn[SAHTS]. Hardware only supports aligned transfers for this feature.                                                                                                                                                                                                                    |

# DMA\_MRn field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20              | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21<br>SRW       | Single register write (Direct mode only; reserved for chaining mode.)                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 | <ul> <li>Normal operation</li> <li>Enable a write to the source address register to simultaneously set MRn[CS], starting a DMA transfer, when MRn[CDSM_SWSM] is also set. Setting this bit and clearing CDSM_SWSM causes a write to the destination address register to simultaneously set MRn[CS], starting a DMA transfer.</li> </ul>                                                                                                                                                        |
| 22<br>EOSIE     | End-of-segments interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 | O Do not generate an interrupt at the completion of a data transfer. CLNDARn[EOSIE] overrides this bit on a link descriptor basis.                                                                                                                                                                                                                                                                                                                                                             |
|                 | 1 Generate an interrupt at the completion of a data transfer (That is, SRn[EOSI] is set). This bit overrides the CLNDARn[EOSIE].                                                                                                                                                                                                                                                                                                                                                               |
| 23<br>EOLNIE    | End-of-links interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 | <ul> <li>Do not generate an interrupt at the completion of a list of DMA transfers.</li> <li>Generate an interrupt at the completion of a list of DMA transfers (That is, NLNDARn[EOLND] is set).</li> </ul>                                                                                                                                                                                                                                                                                   |
| 24<br>EOLSIE    | End-of-lists interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| EOLSIE          | 0 Do not generate an interrupt at the completion of all DMA transfers.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 | 1 Generate an interrupt at the completion of all DMA transfers (That is, NLNDARn[EOLND] and NLSDARn[EOLSD] are set).                                                                                                                                                                                                                                                                                                                                                                           |
| 25<br>EIE       | Error interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 | <ul> <li>Do not generate an interrupt if a programming or transfer error is detected.</li> <li>Generate an interrupt if a programming or transfer error is detected.</li> </ul>                                                                                                                                                                                                                                                                                                                |
| 26<br>XFE       | Extended features enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ALE             | <ul> <li>Disable striding feature in direct mode or disable list chaining feature in chaining mode.</li> <li>Disable striding feature in direct mode or disable list chaining feature in chaining mode.</li> </ul>                                                                                                                                                                                                                                                                             |
| 27<br>CDSM_SWSM | <ul> <li>In chaining mode, current descriptor start mode/single-write start mode is as follows:</li> <li>In basic mode (MRn[XFE] is cleared), setting this bit causes a write to the current link descriptor address register to simultaneously set MRn[CS], starting a DMA transfer.</li> <li>In extended chaining mode (MRn[XFE] is set), setting this bit causes a write to the current list descriptor address register to simultaneously set MRn[CS], starting a DMA transfer.</li> </ul> |
|                 | In direct mode, setting this bit and MRn[SRW] causes a write to the source address register to simultaneously set MRn[CS], starting a DMA transfer. Clearing this bit and setting MRn[SRW] causes a write to the destination address register to simultaneously set MRn[CS], starting a DMA transfer. This bit must be cleared when MRn[SRW] is cleared.                                                                                                                                       |
| 28<br>CA        | Channel abort                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 | 0 No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 | Cause the current transfer to be aborted and SRn[CB] to be cleared if the channel is busy. The channel remains in the idle state until a new transfer is programmed.                                                                                                                                                                                                                                                                                                                           |
| 29<br>CTM       | Channel transfer mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 | O Configure the channel in chaining mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 1 Configure the channel into direct mode. This means that software is responsible for placing all the required parameters into necessary registers to start the DMA process.                                                                                                                                                                                                                                                                                                                   |

# DMA\_MRn field descriptions (continued)

| Field                                                                                                                                                                                           | Description                                                                                                                                                                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30<br>CC                                                                                                                                                                                        | Channel continue. This bit applies only to chaining mode and is cleared by hardware after the first descriptor read when continuing a transfer. This bit is reserved for external master mode.                                                                                                          |
|                                                                                                                                                                                                 | <ul> <li>No effect</li> <li>The DMA transfer restarts the transferring process starting at the current descriptor address.</li> </ul>                                                                                                                                                                   |
| Channel start. This bit is also automatically set by hardware during single-write start mode a master start enable mode. Note that in external control mode, deasserting DMA_DREQ doe this bit. |                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                 | <ul> <li>Halt the DMA process if channel is busy (SRn[CB] is set). No effect if the channel is not busy.</li> <li>Start the DMA process if channel is not busy (CB is cleared). If the channel was halted (CS = 0 and CB = 1), the transfer continues from the point at which it was halted.</li> </ul> |

# 13.3.2 DMA status register (DMA\_SRn)

The status registers report various DMA conditions during and after a DMA transfer.



## DMA\_SRn field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–23<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                    |
| 24<br>TE    | Transfer error (Bit reset, write 1 to clear)  O No error condition during the DMA transfer  Error condition during the DMA transfer. See DMA errors, for additional information.                                                                                                                                                    |
| 25<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                    |
| 26<br>CH    | <ul> <li>Channel halted. Cleared automatically by hardware if MR n [CS] is set again for resuming a halted transfer</li> <li>Channel is not halted. If software attempts to halt an idle channel (SRn[CB] is cleared), this bit remains 0.</li> <li>DMA transfer was successfully halted by software and can be resumed.</li> </ul> |
| 27<br>PE    | Programming error (bit reset, write 1 to clear)  O No programming error detected  A programming error is detected that prevents the DMA transfer from occurring.                                                                                                                                                                    |
| 28<br>EOLNI | End-of-links interrupt. After transferring the last block of data in the last link descriptor, if MRn[EOLNIE] is set, then this bit is set and an interrupt is generated.  (Bit reset, write 1 to clear)                                                                                                                            |
| 29<br>CB    | Channel busy  O DMA transfer is finished, an error occurred, or a channel abort occurred.  1 DMA transfer is currently in progress.                                                                                                                                                                                                 |
| 30<br>EOSI  | End-of-segment interrupt. In chaining mode, after finishing a data transfer, if MRn[EOSIE] is set or if CLNDARn[EOSIE] is set, this bit gets set and an interrupt is generated. In direct mode, if MRn[EOSIE] is set, this bit gets set and an interrupt is generated.  (Bit reset, write 1 to clear)                               |
| 31<br>EOLSI | End-of-list interrupt. After transferring the last block of data in the last list descriptor, if MRn[EOLSIE] is set, then this bit is set and an interrupt is generated.  (Bit reset, write 1 to clear)                                                                                                                             |

# 13.3.3 DMA current link descriptor extended address register (DMA\_ECLNDARn)

These registers contain the upper 4 bits of the address of the current link descriptor. See DMA current link descriptor address register (DMA\_CLNDARn) for a description of basic chaining mode.

Address:  $2_{1000h}$  base + 108h offset + (128d × i), where i=0d to 3d



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### DMA\_ECLNDARn field descriptions

| Field           | Description                                                               |
|-----------------|---------------------------------------------------------------------------|
| 0–27<br>-       | This field is reserved. Reserved                                          |
| 28–31<br>ECLNDA | Current link descriptor extended address (upper 4 bits of 36-bit address) |

# 13.3.4 DMA current link descriptor address register (DMA\_CLNDARn)

Current link descriptor address registers contain the address of the current link descriptor. For devices with 36-bit addressing, the upper 4 bits of the address are described in DMA current link descriptor extended address register (DMA\_ECLNDAR*n*).

In basic chaining mode, shown in the figure below, software must initialize these registers to point to the first link descriptors in memory.



Figure 13-11. Basic Chaining Mode Flow Chart

After the current descriptor is processed, the current link descriptor address register is loaded from the next link descriptor address registers and NLNDAR *n* [EOLND] in the next link descriptor address register is examined. If EOLND is zero, the DMA controller

reads in the new current link descriptor for processing. If EOLND is set, the last descriptor of the list was just completed. If extended chaining mode is not enabled, all DMA transfers are complete and the DMA controller halts.

If extended chaining mode is enabled, the DMA controller examines the state of NLSDAR *n* [EOLSD] in the next list descriptor address register. If EOLSD is clear, the controller loads the contents of the next list descriptor address register into the current list descriptor address register and reads the new list descriptor from memory. If EOLSD is set, all DMA transfers are complete and the DMA controller halts.



Field Description 0-26 Current link descriptor address. Contains the current descriptor address of the buffer descriptor in memory. The descriptor must be aligned to a 32-byte boundary. (This is the lower portion of the 36-bit **CLNDA** address formed by CLNDARn[CLNDA] and ECLNDARn[ECLNDA].) 27 This field is reserved. Reserved 28 End-of-segment interrupt enable **EOSIE** Do not generate an interrupt upon completion of the current DMA transfer for the current link descriptor. Generate an interrupt upon completion of the current DMA transfer for the current link descriptor. 29-31 This field is reserved. Reserved

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 13.3.5 DMA source attributes register (DMA\_SATR*n*)

The source attributes registers contain the transaction attributes to be used for the DMA operation. Stride mode is enabled by setting SATR n [SSME].



## DMA\_SATRn field descriptions

| Field               | Description                                                                                                                                                                                                                                                   |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–6<br>-            | This field is reserved. Reserved                                                                                                                                                                                                                              |
| 7<br>SSME           | Source stride mode enable  Ignored in basic mode (MRn[XFE] is cleared). Striding on the source address can be accomplished by enabling SATRn[SSME] and setting the desired stride size and distance in the SSRn.  O Stride mode disabled  Stride mode enabled |
| 8–11<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                              |
| 12–15<br>SREADTTYPE | DMA source transaction type. Reserved values result in a programming error being detected and logged in SR[PE].                                                                                                                                               |
|                     | Transaction type to run on local address space.                                                                                                                                                                                                               |
|                     | Patterns not shown are reserved.                                                                                                                                                                                                                              |
|                     | 0100 Read, do not snoop local processor                                                                                                                                                                                                                       |
|                     | 0101 Read, snoop local processor                                                                                                                                                                                                                              |
|                     | 0111 Read, unlock L2 cache line                                                                                                                                                                                                                               |
| 16–27<br>-          | This field is reserved. Reserved                                                                                                                                                                                                                              |
| 28–31<br>ESAD       | Extended source address.  ESAD represents the four high-order bits of the 36-bit source address.                                                                                                                                                              |

# 13.3.6 DMA source address register (DMA\_SARn)

The source address registers contain the address from which the DMA controller reads data. In direct mode, if MR n [CDSM\_SWSM] and MR n [SRW] are set, a write to this register simultaneously sets MR n [CS], starting a DMA transfer. Software must ensure that this is a valid address.



## DMA\_SARn field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>SAD | Source address. This register contains the low-order bits of the 36 -bit source address of the DMA transfer. The contents are updated after every DMA write operation unless the final stride of a striding operation is less than the stride size, in which case it remains equal to the address from which the last stride began. |

# 13.3.7 DMA destination attributes register (DMA\_DATRn)

The destination attributes registers contain the transaction attributes for the DMA operation. Stride mode is enabled by setting DATR *n* [DSME].



## DMA\_DATRn field descriptions

| Field                | Description                                                                                                                                                                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–6<br>-             | This field is reserved. Reserved                                                                                                                                                                                                                            |
| 7<br>DSME            | Destination stride mode enable  Ignored in basic mode (MRn[XFE] is cleared). Striding on the destination address can be accomplished by setting DSME and setting the desired stride size and distance in DSRn.  O Stride mode disabled  Stride mode enabled |
| 8–11<br>-            | This field is reserved. Reserved                                                                                                                                                                                                                            |
| 12–15<br>DWRITETTYPE | DMA destination transaction type. Reserved values result in a programming error being detected and logged in SR[PE].                                                                                                                                        |
|                      | Transaction type to run on local address space                                                                                                                                                                                                              |
|                      | 0000-0011 Reserved                                                                                                                                                                                                                                          |
|                      | 0100 Write, do not snoop local processor                                                                                                                                                                                                                    |
|                      | 0101 Write, snoop local processor                                                                                                                                                                                                                           |
|                      | 0110 Write, allocate L2 cache line                                                                                                                                                                                                                          |
|                      | 0111 Write, allocate and lock L2 cache line                                                                                                                                                                                                                 |
|                      | 1000-1111 Reserved                                                                                                                                                                                                                                          |
| 16–27                | This field is reserved. Reserved                                                                                                                                                                                                                            |
| 28–31                | Extended destination address.                                                                                                                                                                                                                               |
| EDAD                 | EDAD represents the four high-order bits of the 36-bit destination address.                                                                                                                                                                                 |

# 13.3.8 DMA destination address register (DMA\_DARn)

The destination address registers contain the addresses to which the DMA controller writes data.

In direct mode, if MR n [SRW] is set and MR n [CDSM\_SWSM] is cleared, a write to this register simultaneously sets MR n [CS], starting a DMA transfer. Software must ensure that this is a valid address.



## DMA\_DARn field descriptions

| Field | Description                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31  | Destination address. This register contains the low-order bits of the 36-bit destination address of the DMA                                                                                                                      |
| DAD   | transfer. The contents are updated after every DMA write operation unless the final stride of a striding operation is less than the stride size, in which case it remains equal to the address from which the last stride began. |

# 13.3.9 DMA byte count register (DMA\_BCRn)

The byte count register contains the number of bytes to transfer.





## DMA\_BCRn field descriptions

| Field      | Description                                                                                                                                                                               |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–5<br>-   | This field is reserved. Reserved                                                                                                                                                          |
| 6–31<br>BC | Byte count. Contains the number of bytes to transfer. The value in this register is decremented after each DMA read operation. The maximum transfer size is (2 <sup>26</sup> ) - 1 bytes. |

# 13.3.10 DMA extended next link descriptor address register (DMA\_ENLNDARn)

These registers contain the upper 4 bits of the address of the next link descriptor in memory. See DMA next link descriptor address register (DMA\_NLNDAR*n*).

Address:  $2_{1000h}$  base + 124h offset + (128d × i), where i=0d to 3d



## DMA\_ENLNDARn field descriptions

| Field           | Description                                                                 |
|-----------------|-----------------------------------------------------------------------------|
| 0–27<br>-       | This field is reserved. Reserved                                            |
| 28–31<br>ENLNDA | Next link descriptor extended address bits (upper 4 bits of 36-bit address) |

#### 13.3.11 DMA next link descriptor address register (DMA\_NLNDARn)

Current link descriptor address registers contain the address for the next link descriptor in memory. For devices with 36-bit addressing, the upper 4 bits of the address are described in DMA extended next link descriptor address register (DMA\_ENLNDARn).

Contents transferred to the current descriptor address registers become effective for the current transfer in basic and extended chaining modes.



**Field** Description Next link descriptor address. Contains the next link descriptor address in memory. The descriptor must be **NLNDA** aligned to a 32-byte boundary.

Table continues on the next page...

0-26

## DMA\_NLNDARn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                       |
| 28<br>NDEOSIE | Next descriptor end-of-segment interrupt enable  0 Do not generate an interrupt if the current DMA transfer for the current descriptor is finished.  1 Generate an interrupt if the current DMA transfer for the current descriptor is finished.                                                                                                                                       |
| 29–30<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                       |
| 31<br>EOLND   | <ul> <li>End-of-links descriptor. This bit is ignored in direct mode.</li> <li>This descriptor is not the last link descriptor in memory for this list.</li> <li>This descriptor is the last link descriptor in memory for this list. If this bit is set, the DMA controller advances to the next list descriptor in memory if NLSDARn[EOLSD] is also set in extended mode.</li> </ul> |

# 13.3.12 DMA extended current list descriptor address register (DMA\_ECLSDARn)

These registers contain the upper 4 bits of the current address of the list descriptor in memory in extended chaining mode. See DMA current list descriptor address register (DMA\_CLSDAR*n*).

Address:  $2_{1000h}$  base + 130h offset + (128d × i), where i=0d to 3d



### DMA\_ECLSDARn field descriptions

| Field           | Description                                                                    |
|-----------------|--------------------------------------------------------------------------------|
| 0–27<br>-       | This field is reserved. Reserved                                               |
| 28–31<br>ECLSDA | Current list descriptor extended address bits (upper 4 bits of 36-bit address) |

# 13.3.13 DMA current list descriptor address register (DMA\_CLSDARn)

The current list descriptor address registers contain the current address of the list descriptor in memory in extended chaining mode. For chips with 36-bit addressing, the upper 4 bits of the address are described in DMA extended current list descriptor address register (DMA\_ECLSDARn).

In extended chaining mode, software must initialize CLS DAR n and ECLSDAR n to point to the first list descriptor in memory. After finishing the last link descriptor in the current list, the DMA controller loads the contents of the next list descriptor address register into the current list descriptor address register. If NLSDAR n [EOLSD] in the next list descriptor address register is clear, the DMA controller reads the new current list descriptor from memory to process that list. If EOLSD in the next list descriptor address register is set and the last link in the current list is finished, all DMA transfers are complete.





#### DMA\_CLSDARn field descriptions

| Field      | Description                                                                                                                                                                                                                    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Current list descriptor address. Contains the low-order bits of the 36-bit current list descriptor address of the buffer descriptor in memory in extended chaining mode. The descriptor must be aligned to a 32-byte boundary. |
| 27–31<br>- | This field is reserved. Reserved                                                                                                                                                                                               |

# 13.3.14 DMA extended next list descriptor address register (DMA\_ENLSDARn)

These registers contain the upper 4 bits of the address of the next list descriptor in memory. See DMA next list descriptor address register (DMA\_NLSDAR*n*).



## DMA\_ENLSDARn field descriptions

| Field           | Description                                                                 |
|-----------------|-----------------------------------------------------------------------------|
| 0–27<br>-       | This field is reserved. Reserved                                            |
| 28–31<br>ENLSDA | Next list descriptor extended address bits (upper 4 bits of 36-bit address) |

# 13.3.15 DMA next list descriptor address register (DMA\_NLSDARn)

The next list descriptor address registers contain the address for the next list descriptor in memory. For devices with 36-bit addressing, the upper 4 bits of the address are described in DMA extended next list descriptor address register (DMA\_ENLSDAR*n*).

If the contents are transferred to the current list descriptor address register, they become effective for the current transfer in extended chaining mode.



#### **DMA** controller memory map



## DMA\_NLSDARn field descriptions

| Field         | Description                                                                                                                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–26<br>NLSDA | Next list descriptor address. Contains the low-order bits of the 36-bit next descriptor address of the buffer descriptor in memory. The descriptor must be aligned on a 32-byte boundary.                  |
| 27–30<br>-    | This field is reserved. Reserved                                                                                                                                                                           |
| 31<br>EOLSD   | End-of-lists descriptor. This bit is ignored in direct mode.                                                                                                                                               |
|               | <ul> <li>This list descriptor is not the last list descriptor in memory.</li> <li>This list descriptor is the last list descriptor in memory. If this bit is set, then the DMA controller halts</li> </ul> |
|               | after the last link descriptor transaction is finished.                                                                                                                                                    |

# 13.3.16 DMA source stride register (DMA\_SSRn)

The source stride register contains the stride size and distance. Note that the source stride information is loaded when a new list descriptor is read from memory. Therefore, the source stride register is applicable for all link descriptors in the new list. Changing the source stride information for a link requires that a new list be generated.

Address:  $2_{1000h}$  base + 140h offset + (128d × i), where i=0d to 3d



#### DMA\_SSRn field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–7   | This field is reserved. |
| -     | Reserved                |

## DMA\_SSR*n* field descriptions (continued)

| Field        | Description                                                                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 1            | Source stride size. Number of bytes to transfer before jumping to the next address as specified in the source stride distance field. |
| 20–31<br>SSD | Source stride distance. The source stride distance in bytes from start byte to start byte.                                           |

# 13.3.17 DMA destination stride register (DMA\_DSRn)

The destination stride register contains the stride size, and distance. Note that the destination stride information is loaded when a new list descriptor is read from memory. Therefore, the destination stride register is applicable for all link descriptors in the new list. Changing the destination stride information for a link requires that a new list be generated.

Address:  $2_{1000h}$  base + 144h offset + (128d  $\times$  i), where i=0d to 3d



## DMA\_DSRn field descriptions

| Field        | Description                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7          | This field is reserved. Reserved                                                                                                               |
| 8–19<br>DSS  | Destination stride size. Number of bytes to transfer before jumping to the next address as specified in the destination stride distance field. |
| 20–31<br>DSD | Destination stride distance. The destination stride distance in bytes from start byte to start byte.                                           |

# 13.3.18 DMA general status register (DMA\_DGSR)

The DMA general status register combines all of the status bits each channel into one register. This register is read-only.







# DMA\_DGSR field descriptions

| Field       | Description                                            |
|-------------|--------------------------------------------------------|
| 0<br>TE0    | Transfer error, channel 0  0 Normal operation          |
|             | 1 An error condition occurred during the DMA transfer. |
| 1 -         | This field is reserved. Reserved                       |
| 2<br>CH0    | Channel halted, channel 0                              |
| 3<br>PE0    | Programming error, channel 0                           |
| 4<br>EOLNI0 | End-of-links interrupt, channel 0                      |
| 5<br>CB0    | Channel busy, channel 0                                |
| 6<br>EOSI0  | End-of-segment interrupt, channel 0                    |
| 7<br>EOLSI0 | End-of-lists/direct interrupt, channel 0               |

#### **DMA** controller memory map

# **DMA\_DGSR** field descriptions (continued)

| Field        | Description                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------|
| 8<br>TE1     | Transfer error, channel 1  0 Normal operation 1 An error condition occurred during the DMA transfer.  |
| 9 -          | This field is reserved. Reserved                                                                      |
| 10<br>CH1    | Channel halted, channel 1                                                                             |
| 11<br>PE1    | Programming error, channel 1                                                                          |
| 12<br>EOLNI1 | End-of-links interrupt, channel 1                                                                     |
| 13<br>CB1    | Channel busy, channel 1                                                                               |
| 14<br>EOSI1  | End-of-segment interrupt, channel 1                                                                   |
| 15<br>EOLSI1 | End-of-lists/direct interrupt, channel 1                                                              |
| 16<br>TE2    | Transfer error, channel 2  0 Normal operation  1 An error condition occurred during the DMA transfer. |
| 17           | This field is reserved. Reserved                                                                      |
| 18<br>CH2    | Channel halted, channel 2                                                                             |
| 19<br>PE2    | Programming error, channel 2                                                                          |
| 20<br>EOLNI2 | End-of-links interrupt, channel 2                                                                     |
| 21<br>CB2    | Channel busy, channel 2                                                                               |
| 22<br>EOSI2  | End-of-segment interrupt, channel 2                                                                   |
| 23<br>EOLSI2 | End-of-lists/direct interrupt, channel 2                                                              |
| 24<br>TE3    | Transfer error, channel 3  O Normal operation  An error condition occurred during the DMA transfer.   |
| 25<br>-      | This field is reserved. Reserved                                                                      |
| 26<br>CH3    | Channel halted, channel 3                                                                             |
| 27<br>PE3    | Programming error, channel 3                                                                          |

## DMA\_DGSR field descriptions (continued)

| Field        | Description                              |
|--------------|------------------------------------------|
| 28<br>EOLNI3 | End-of-links interrupt, channel 3        |
| 29<br>CB3    | Channel busy, channel 3                  |
| 30<br>EOSI3  | End-of-segment interrupt, channel 3      |
| 31<br>EOLSI3 | End-of-lists/direct interrupt, channel 3 |

# 13.4 DMA functional description

This section describes the function of the DMA controller.

# 13.4.1 DMA channel operation

All DMA channels support two different modes of operation: a basic mode (MRn[XFE] is cleared) and an extended mode (MRn[XFE] is set). In both modes, a channel can be activated by clearing and setting MRn[CS], or through the single-write start mode using MRn[CDSM\_SWSM] and MRn[SRW], or through an external control mode using MRn[EMS\_EN] and the external DMA\_DREQ signal.

In basic mode, the channel can be programmed in basic direct mode or basic chaining mode. In extended mode, the channel can be programmed in extended direct mode or extended chaining mode. Extended mode provides more capabilities, such as extended descriptor chaining, striding capabilities, and a more flexible descriptor structure.

The DMA controller supports misaligned transfers for both the source and destination addresses. In order to maximize performance, the source and destination engines issue one or more transactions to reach the desired alignment based on the rules described in Source/destination transaction size calculations. The DMA always reads/writes the maximum number of bytes for a given transfer as described by the capability inputs of the DMA controller except for globally coherent transactions that use the size of the cache coherence granule as described by the mode select input.

The DMA controller supports bandwidth control, which prevents a channel from consuming all the data bandwidth in the controller. Each channel is allowed to consume the bandwidth of the shared resources as specified by the bandwidth control value. After the channel uses its allotted bandwidth, the arbiter grants the next channel access to the shared resources. The arbitration is round robin between the channels. This feature is also

#### **DMA functional description**

used to implement the external control pause feature. If the external control start and pause are enabled in the MRn, the channel enters a paused state after transferring the data described in the bandwidth control. External control can restart the channel from a paused state.

The DMA programming model permits software to program each DMA engine independently to interrupt on completed segment, chain, or error. It also provides the capability for software to resume the DMA engine from a hardware halted condition by setting the channel continue bit, MRn[CC]. See Table 13-90 for more complete descriptions of the channel states and state transitions.

## 13.4.1.1 Source/destination transaction size calculations

The DMA controller may issue smaller transactions from the source and destination address engines in an effort to reach alignment for improved performance.

The flow chart below shows the decision points made in determining the transaction size. The starting *Txfer\_Size* is determined by min(BCR[BC],MR[BWC]), *Stride\_En* is determined by SATR*n*[SSME] or DATR*n*[DSME], and *Stride\_Size* is determined by SSR*n*[SSS] or DSR*n*[DSS].



Figure 13-95. Source/destination engine transaction size flow chart

For example, if BCR[BC]=512 bytes and MR[BWC]=256 bytes, reading from starting address 0x5D0 will result in the following transaction sizes:

```
-- Channel arbitration --
0x5D0 - 16 bytes
0x5E0 - 32 bytes
0x600 - 128 bytes
0x680 - 64 bytes
0x6C0 - 16 bytes
-- Channel arbitration --
0x6D0 - 16 bytes
0x6E0 - 32 bytes
0x700 - 128 bytes
0x780 - 64 bytes
0x7C0 - 16 bytes
```

#### **DMA functional description**

In the example above, the bandwidth control limits the channel from ever reaching the maximum transaction size of 256 bytes. Software should align addresses or increase the available bandwidth for best performance.

## 13.4.1.2 Basic DMA mode transfer

This mode is primarily included for backward compatibility with existing DMA controllers which use a simple programming model. This is the default mode out of reset.

The different modes of operation under the basic mode are explained in the following sections.

### 13.4.1.2.1 Basic direct mode

In basic direct mode, the DMA controller does not read descriptors from memory, but instead uses the current parameters programmed in the DMA registers to start the DMA transfer.

Software is responsible for initializing SARn, SATRn, DARn, DATRn, and BCRn registers. The DMA transfer is started when MRn[CS] is set. Software is expected to program all the appropriate registers before setting MRn[CS] to a 1. The transfer is finished after all the bytes specified in the byte count register have been transferred or if an error condition occurs. The sequence of events to start and complete a transfer in basic direct mode is as follows:

- 1. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 2. Initialize SARn, SATRn, DARn, DATRn and BCRn.
- 3. Set the mode register channel transfer mode bit, MR*n*[CTM], to indicate direct mode. Other control parameters may also be initialized in the mode register.
- 4. Clear, then set the mode register channel start bit, MRn[CS], to start the DMA transfer.
- 5. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 6. SRn[CB] is automatically cleared by the DMA controller after the transfer is finished, or if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if a transfer error occurs.
- 7. End of segment interrupt is generated if MRn[EOSIE] is set.

## 13.4.1.2.2 Basic, direct, single-write start mode

In basic direct single-write start mode, the DMA controller does not read descriptors from memory, but instead uses the current parameters programmed in the DMA registers to start the DMA transfer.

Software is responsible for initializing the SATR*n*, DATR*n*, and BCR*n* registers. Setting MR*n*[SRW] configures the DMA controller to begin the DMA transfer either when SAR*n* is written or when DAR*n* is written, determined by the state of MR*n*[CDSM\_SWSM]. Writing to SAR*n* initiates the DMA transfer if MR*n*[CDSM\_SWSM] is set. Writing to DAR*n* initiates the DMA transfer if MR*n*[CDSM\_SWSM] is cleared. The DMA controller automatically sets the channel start bit, MR*n*[CS]. Software is expected to program all the appropriate registers before writing the source or destination address registers. The transfer is finished after all the bytes specified in the byte count register have been transferred or if an error condition occurs. The sequence of events to start and complete a transfer in single-write start basic direct mode is as follows:

- 1. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 2. Initialize the source attributes (SATRn), DATRn, and BCRn registers.
- 3. Set the mode register channel transfer mode bit, MRn[CTM], and the single-write start direct mode bit, MRn[SRW]. Other control parameters may also be initialized in the mode register. Set MRn[CDSM\_SWSM] for transfers started using SARn. Clear MRn[CDSM\_SWSM] for transfers started using the DARn.
- 4. A write to the source or destination address register starts the DMA transfer and automatically sets MRn[CS].
- 5. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 6. SRn[CB] is automatically cleared by the DMA controller after the transfer is finished, if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if a transfer error occurs.
- 7. End of segment interrupt is generated if MRn[EOSIE] is set.

## 13.4.1.2.3 Basic chaining mode

In basic chaining mode, software must first build link descriptor segments in memory.

Then the current link descriptor address register must be initialized to point to the first descriptor in memory. The DMA controller loads descriptors from memory prior to a DMA transfer. The DMA controller begins the transfer according to the link descriptor information loaded for the segment. After the current segment is finished, the DMA controller reads the next link descriptor from memory and begins another DMA transfer.

#### **DMA functional description**

The transfer is finished if the current link descriptor is the last one in memory or if an error condition occurs. The sequence of events to start and complete a transfer in chaining mode is as follows:

- 1. Build link descriptor segments in memory.
- 2. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 3. Initialize CLNDARn and ECLNDARn to point to the first link descriptor in memory.
- 4. Clear the mode register channel transfer mode bit, MRn[CTM], as well as MRn[XFE], to indicate basic chaining mode. Other control parameters may also be initialized in the mode register.
- 5. Clear and then set the mode register channel start bit, MRn[CS], to start the DMA transfer.
- 6. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 7. SRn[CB] is automatically cleared by the DMA controller after finishing the transfer of the last descriptor segment, if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if an error occurs during any of the transfers.

## 13.4.1.2.4 Basic chaining, single-write start mode

Basic chaining, single-write start mode allows a chain to be started by writing the current link descriptor address register (CLNDAR*n*).

(Note that ECLNDAR*n* must be written *first* so that the full 36-bit descriptor address is present when the chain starts.) Setting MR*n*[CDSM\_SWSM] in the mode register causes MR*n*[CS] to be automatically set when the current link descriptor address register is written. The sequence of events to start and complete a chain using single-write start mode is as follows:

- 1. Set the mode register current descriptor start mode bit, MRn[CDSM\_SWSM], and clear the extended features enable bit MRn[XFE]. Also, clear the channel transfer mode bit, MRn[CTM]. This initialization indicates basic chaining and single-write start mode. Also other control parameters may be initialized in the mode register.
- 2. Build link descriptor segments in memory.
- 3. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 4. Initialize CLNDAR*n* and ECLNDAR*n* to point to the first descriptor segment in memory. This write automatically causes the DMA controller to begin the link descriptor fetch and set MR*n*[CS].
- 5. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 6. SRn[CB] is automatically cleared by the DMA controller after finishing the transfer of the last descriptor segment, if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if an error occurs during any of the transfers.

## 13.4.1.3 Extended DMA mode transfer

The extended DMA mode also operates in chaining and direct mode.

It offers additional capability over the basic mode by supporting striding and a more flexible descriptor structure. This additional functionality also requires a new and more complex programming model. The extended DMA mode is activated by setting MRn[XFE].

#### 13.4.1.3.1 Extended direct mode

Extended direct mode has the same functionality as basic direct mode with the addition of stride capabilities.

The bit settings are the same as in direct mode with the exception of the MRn[XFE] being set. Striding on the source address can be accomplished by setting SATRn[SSME] and setting the desired stride size and distance in SSRn. Striding on the destination address can be accomplished by setting DATRn[DSME] and setting the desired stride size and distance in DSRn.

## 13.4.1.3.2 Extended direct, single-write start mode

Extended direct, single-write start mode has the same functionality as the basic direct single-write start mode with the addition of stride capabilities.

The bit settings are also the same with the exception of MRn[XFE] being set. Striding on the source address can be accomplished by setting SATRn[SSME] and setting the desired stride size and distance in SSRn. Striding on the destination address can be accomplished by setting DATRn[DSME] and setting the desired stride size and distance in DSRn.

## 13.4.1.3.3 Extended chaining mode

In extended chaining mode, the software must first build list and link descriptor segments in memory.

Then CLSDAR*n* and ECLSDAR*n* must be initialized to point to the first list descriptor in memory. The DMA controller loads list descriptors and link descriptors from memory prior to a DMA transfer. The DMA controller begins the transfer according to the link descriptor information loaded. Once the current link descriptor is finished, the DMA controller reads the next link descriptor from memory and begins another DMA transfer. If the current link descriptor is the last in the list, the DMA controller reads the next list

#### **DMA functional description**

descriptor in memory. The transfer is finished if the current link descriptor is the last one in the last list in memory or if an error condition occurs. The sequence of events to start and complete a transfer in extended chaining mode is as follows:

- 1. Build link and list descriptor segments in memory.
- 2. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 3. Initialize CLSDAR*n* and ECLSDAR*n* to point to the first list descriptor in memory.
- 4. Clear the mode register channel transfer mode bit, MR*n*[CTM], to indicate chaining mode. MR*n*[XFE] must be set to indicate extended DMA mode. Other control parameters may also be initialized in the mode register.
- 5. Clear and then set the mode register channel start bit, MRn[CS], to start the DMA transfer.
- 6. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 7. SRn[CB] is automatically cleared by the DMA controller after finishing the transfer of the last descriptor segment, if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if an error occurs during any of the transfers.

## 13.4.1.3.4 Extended chaining, single-write start mode

In the extended mode, the single-write start feature allows a chain to be started by writing the current list descriptor pointer.

Setting MRn[CDSM\_SWSM] causes MRn[CS] to be set automatically when CLSDARn is written. (Note that ECLSDARn must be written *first* so that the full 36-bit descriptor address is present when the chain starts.) The sequence of events to start and complete an extended chain using single-write start mode is as follows:

- 1. Set MRn[CDSM\_SWSM] and MRn[XFE] and clear MRn[CTM] to indicate extended chaining and single-write start mode. Also other control parameters may be initialized in the mode register.
- 2. Build list and link descriptor segments in local memory.
- 3. Poll the channel state (see Table 13-90) to confirm that the specific DMA channel is idle.
- 4. Initialize the current list descriptor address register to point to the first list descriptor segment in memory. This write automatically causes the DMA controller to begin the list descriptor fetch and set MRn[CS].
- 5. SRn[CB] is set by the DMA controller to indicate the DMA transfer is in progress.
- 6. SRn[CB] is automatically cleared by the DMA controller after finishing the transfer of the last descriptor segment, or if the transfer is aborted (MRn[CA] transitions from a 0 to 1), or if an error occurs during any of the transfers.

## 13.4.1.4 External control mode transfer

An external control can be used to control all DMA channels by setting MR*n*[EMS\_EN].

The external control can direct the DMA channel in the following transfer modes:

- Basic direct
- Basic chaining
- Extended direct
- Extended chaining

The external control and the DMA controller use a well defined protocol to communicate. The external control can start or restart a paused DMA transfer. The DMA controller acknowledges a DMA transfer in progress and also indicates a transfer completion. Note that external control cannot cause a channel to enter a paused state.

The pause feature can be enabled by setting MRn[EMP\_EN]. MRn[BWC] specifies how much data to allow a specific channel to transfer before entering a paused state by clearing MRn[CS]. Note however, that write data for a paused transfer may not have reached the target interface when so indicated. The channel can be restarted from a paused state by the asserted edge of  $\overline{\text{DREQ}}$  as driven by an external master. In chaining modes, the channel does not pause for descriptor fetch transfer; it only pauses during the actual data transfer.

Note that when operating the DMA in chaining mode the register byte count field, BCR[BC], must be initialized to zero before enabling the pause feature. In chaining modes, the channel does not pause for descriptor fetch transfer.

The following signals are defined for the external control interface:

- DMA\_DREQ-Asserting edge triggers a DMA transfer start or restart from a pause request. Sets MRn[CS]. (Note that negating DMA\_DREQ does NOT clear MRn[CS].)
- DMA\_DACK-Indicates a DMA transfer currently in progress. SRn[CB] is set.
- DMA\_DDONE-Indicates the completion of the DMA controller's involvement in the transfer and the readiness to accept a new DMA command. SRn[CB] is clear. Note however, that write data may still be queued at the target interface or in the process of transfer on an external interface.

Detailed descriptions of the external control interface are in Table 13-3. The timing diagram of the external control interface is shown in this figure.

#### **DMA functional description**



Figure 13-96. External control interface timing

# 13.4.1.5 Channel continue mode for cascading transfer chains

The channel continue mode (enabled when MRn[CC] is set) offers software the flexibility of having the DMA controller start on descriptors that have already been programmed while software continues to build more descriptors in memory.

Software can set the end-of-links descriptor (EOLND) in basic mode, or end-of-lists descriptor (EOLSD) in extended mode, to cause the channel to go into a halted state while software continues to build other descriptors in memory. Software can then set CC to force hardware to continue where it left off. Channel continue is only meaningful for chaining modes, not direct mode.

If CC is set by software while the channel is busy with a transfer, the DMA controller finishes all transfers until it reaches the EOLND in basic mode or EOLSD in extended mode. The DMA controller then refetches the last link descriptor in basic mode or the last list descriptor in extended mode and clears the channel continue bit. If EOLND or EOLSD is still set for their respective modes, the DMA controller remains in the idle state. If EOLND or EOLSD is not set, the DMA controller continues the transfer by refetching the new descriptor. The channel busy (SRn[CB]) bit is cleared when the DMA controller reaches EOLND/EOLSD and is set again when it initiates the refetch of the link or list descriptor.

If CC is set by software while the channel is not busy with a transfer, the DMA controller refetches the last link descriptor in basic mode, or the last list descriptor in extended mode and clears the channel continue bit. If EOLND or EOLSD is still set for their

respective modes, the DMA controller remains in the idle state. If the EOLND or EOLSD bits are not set, the DMA controller continues the transfer by refetching the new descriptor.

## 13.4.1.5.1 Basic mode

On a channel continue, the descriptor at the current link descriptor address registers (CLNDARn and ECLNDARn) is refetched to get the next link descriptor address field as updated by software.

The channel halts if NLNDAR*n*[EOLND] is still set. If EOLND is zero, the next link descriptor address is copied into CLNDAR*n* and ECLNDAR*n* and the channel continues with another descriptor fetch of the current link descriptor address. As a result, two link descriptor fetches always exist after channel continue before starting the first transfer.

#### 13.4.1.5.2 Extended mode

On a channel continue, the descriptor at the current list descriptor (CLSDARn and ECLSDARn) address register is refetched to get the next list descriptor address field as updated by software.

The channel halts if NLSDAR*n*[EOLSD] is still set. If not, the next list descriptor address is copied into the CLSDAR*n* and ECLSDAR*n* registers and the channel continues with another descriptor fetch of the current list descriptor address. As a result, two list descriptor fetches always exist after channel continue before the first link descriptor fetch and the first transfer.

## 13.4.1.6 Channel abort

Software can abort a previously initiated transfer by setting MRn[CA].

Once the DMA channel controller detects a zero-to-one transition of MRn[CA], it finishes the current sub-block transfer and halts all further activity. The controller then waits for all previously initiated transfers from the specified channel to drain and clears SRn[CB]. Successful completion of a software initiated abort request can be recognized by MRn[CA] being set and SRn[CB] being cleared. Obviously, if the controller was already halted because of an error condition (SRn[TE] is set), or the channel has completed all transfers, then SRn[CB] being cleared may not signify that the controller entered a halt state due to the abort request.

## 13.4.1.7 Bandwidth control

MRn[BWC] specifies how much data to allow a specific channel to transfer before allowing the next channel to use the shared data transfer hardware.

This promotes equitable bandwidth allocation between channels. However, if only one channel is busy, hardware overrides the specified bandwidth control size value. The DMA controller allows a channel to transfer up to 1 Kbyte at a time when no other channel is active.

The maximum performance can be achieved on a single channel by disabling bandwidth control. This is recommended especially if only a single channel is utilized.

## 13.4.1.8 Channel state

This table defines the state of a channel based on the values of the channel start (MRn[CS]), channel busy (SRn[CB]), transfer error (SRn[TE]), and channel continue (MRn[CC]) bits.

| MRn[C<br>S] | SRn[CB | SRn[TE | MRn[C<br>C] | Channel state                                                                                                              |
|-------------|--------|--------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| 0           | 0      | 0      | 0           | Idle state. This is the state of the bits out of reset.                                                                    |
| 0           | 0      | 0      | 1           | Channel continue unexpected. Channel remains idle                                                                          |
| 0           | 0      | 1      | 0           | Error occurred after software halted the channel.                                                                          |
| 0           | 0      | 1      | 1           | Channel continue unexpected. Channel remains in error halt state                                                           |
| 0           | 1      | 0      | 0           | Software halted channel. The channel was busy and software cleared MRn[CS].                                                |
| 0           | 1      | 0      | 1           | Channel remains in halt state.                                                                                             |
| -           | 1      | 1      | -           | The channel has encountered an error condition and it is trying to halt.                                                   |
| 1           | 0      | 0      | 0           | Ready to start a transfer, or transfer completed                                                                           |
| 1           | 0      | 0      | 1           | Continue transfer (only meaningful in chaining mode, not direct mode). In direct mode, the channel continue has no effect. |
| 1           | 0      | 1      | 0           | Error occurred during transfer                                                                                             |
| 1           | 0      | 1      | 1           | Channel remains in error halt state                                                                                        |
| 1           | 1      | 0      | 0           | Transfer in progress                                                                                                       |
| 1           | 1      | 0      | 1           | Continue after reaching the end of list/link, or the first descriptor fetch after channel continue                         |

Table 13-90. Channel state table

### 13.4.1.9 Illustration of stride size and stride distance

If operating in stride mode, the stride size defines the amount of data to transfer before jumping to the next quantity of data as specified by the stride distance.

The stride distance is added to the current base address to point to the next quantity of data to be transferred. This figure illustrates the stride size and distance parameters.



Figure 13-97. Stride size and stride distance

As shown, each time the stride distance is added to the base address, the resulting address becomes the new base address. This sequence repeats until the amount of data transferred equals the transfer size.

## 13.4.2 DMA transfer interfaces

The DMA can be used to achieve data transfers across the entire memory map.

Note that DMA can be used only for outbound read/write transaction on PCI Express.

The DMA controller supports the following transfers:

- Local address space to local address space
- Local address space to PCI Express
- Local address space to eLBC
- PCI Express to local address space
- PCI Express to PCI Express
- PCI Express to eLBC
- eLBC to Local address space
- eLBC to PCI Express
- eLBC to eLBC

# 13.4.3 DMA errors

On a transfer error (for example, non-correctable ECC errors on memory accesses, parity errors on local bus flash controller, address mapping errors, and so on), the DMA halts by setting SRn[TE] and generates an interrupt if MRn[EIE] is set.

On a programming error, the DMA sets SRn[PE] and generates an interrupt if MRn[EIE] is set. The DMA controller detects the following programming errors:

#### **DMA functional description**

- Transfer started with a byte count of zero
- Stride transfer started with a stride size of zero
- Transfer started with a priority of three
- Illegal type, defined by SATR*n*[SREADTTYPE] and DATR*n*[DWRITETTYPE], used for the transfer.

# 13.4.4 DMA descriptors

The DMA engine recognizes the following types of descriptors:

- List descriptors connect lists of link descriptors.
- Link descriptors describe the DMA activity that is to take place.

DMA descriptors are built in either local or remote memory and are connected by the next descriptor fields. Only link descriptors contain information for the DMA controller to transfer data. Software must ensure that each descriptor is 32-byte aligned. The last link descriptor in the last list in memory sets the NLNDARn[EOLND] bit in the next link descriptor and NLSDARn[EOLSD] in the next list descriptor fields indicating that these are the last descriptors in memory. Software initializes the current list descriptor address register to point to the first list descriptor in memory. The DMA controller traverses through the descriptor lists until the last link descriptor is met. For each link descriptor in the chain, the DMA controller starts a new DMA transfer with the control parameters specified by that descriptor. Link and list descriptor fetches always snoop the local memory space.

#### NOTE

Software must ensure that each descriptor is aligned on a 32-byte boundary.

This table summarizes the DMA list descriptors.

Table 13-91. List DMA descriptor summary

| Descriptor field                       | Description                                                                                                                                                                                               |  |  |  |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Next list descriptor extended address  | Points to the next list descriptor in memory. After the DMA controller reads the descriptor from memory, this field is loaded into the next list descriptor extended address registers.                   |  |  |  |
| Next list descriptor address           | Points to the next list descriptor in memory. After the DMA controller reads the descriptor from memory, this field is loaded into the next list descriptor address registers.                            |  |  |  |
| First link descriptor extended address | Points to the first link descriptor in memory for this list. After the DMA controller reads the descriptor from memory, this field is loaded into the current link descriptor extended address registers. |  |  |  |
| First link descriptor address          | Points to the first link descriptor in memory for this list. After the DMA controller reads the descriptor from memory, this field is loaded into the current link descriptor address registers.          |  |  |  |
| Source stride                          | Contains the stride information used for the data source if striding is enabled for a link in the list                                                                                                    |  |  |  |
| Destination stride                     | Contains the stride information used for the data destination if striding is enabled for a link in the list                                                                                               |  |  |  |

This table summarizes the DMA link descriptors.

Table 13-92. Link DMA descriptor summary

| Descriptor field                      | Description                                                                                                                                                                                 |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source attributes register            | Contains source transaction attributes                                                                                                                                                      |
| Source address                        | Contains the source address of the DMA transfer. After the DMA controller reads the descriptor from memory, this field is loaded into the Source address register.                          |
| Destination attributes register       | Contains destination transaction attributes                                                                                                                                                 |
| Destination address                   | Contains the destination address of the DMA transfer. After the DMA controller reads the descriptor from memory, this field is loaded into the destination address register.                |
| Next link descriptor extended address | Points to the next link descriptor in memory. After the DMA controller reads the link descriptor from memory, this field is loaded into the extended next link descriptor address registers |
| Next link descriptor address          | Points to the next link descriptor in memory. After the DMA controller reads the link descriptor from memory, this field is loaded into the next link descriptor address registers.         |
| Byte count                            | Contains the number of bytes to transfer. After the DMA controller reads the descriptor from memory, this field is loaded into the byte count register.                                     |

This figure describes the DMA transaction flow.



Figure 13-98. DMA transaction flow with DMA descriptors

This table describes the format of the list descriptors.



Figure 13-99. List descriptor format

This table describes the format of the link descriptors.



Figure 13-100. Link descriptor format

### 13.4.5 DMA controller limitations and restrictions

This section is intended to help software maximize the DMA performance and avoid DMA programming errors.

The limitations of the DMA controller are the following:

- Due to the limited number of buffers that the DMA controller can use, avoid stride sizes less than 64 bytes. Maximum utilization is obtained from strides greater than or equal to 256 bytes. However, small stride sizes can be used for scatter-gather functions.
- Coherent reads or writes are broken up into cache line accesses in the DMA.

The DMA controller restrictions are as follows:

#### **DMA** system considerations

- All interface capabilities from where descriptors are being fetched must support read sizes of 32 bytes or greater.
- If MRn[SAHE] is set, the source interface transfer size capability must be greater than or equal to MRn[SAHTS]. The source address must be aligned to a size specified by SAHTS.
- If MRn[DAHE] is set, the destination interface transfer size capability must be greater than or equal to MRn[DAHTS]. The destination address must be aligned to the size specified by DAHTS.
- Destination striding is not supported if MRn[DAHE] is set and source striding is not supported if MRn[SAHE] is set.
- Striding does not work if the destination transaction type is MESSAGE (DATR[DWRITETTYPE] = 0x0110) because messages have no memory addresses. As well, destination address hold should be disabled (MRn[DAHE] is cleared) unless the destination address hold transfer size indicates an 8-byte message (MRn[DAHTS] = 0x11). Software is responsible for disabling striding and DAHE, in this case, and for ensuring that the bandwidth control is large enough to support the desired message size. Failure to adhere to these restrictions results in boundedly undefined behavior.

# 13.5 DMA system considerations

This section provides information about how to make most effective use of the DMA channels.

The following table lists all of the DMA controllers (both captive and general-purpose) on the device and the most likely DMA targets on and off-chip. The bus controllers themselves cannot initiate DMA transfers; rather, they operate transparently with respect to both on- and off-chip DMA controllers. The codes in the table cells have the following meaning:

- Y-Supported
- NR-Possible, but not recommended. Inefficient use of system resources
- NS-Possible, but not supported. Resulting system behavior is not defined.

#### **Table 13-93. P1021 DMA paths**

| DMA         | On-Chip Targ | ets          | Off-Chip Targ | jets      |          |             |        |
|-------------|--------------|--------------|---------------|-----------|----------|-------------|--------|
| Controllers | L2           | Configuratio | DDR           | Local Bus | Ethernet | PCI Express |        |
|             |              | n Registers  |               |           | Buffers  |             | Engine |

#### Table 13-93. P1021 DMA paths (continued)

| On-chip  | Ethernet          | Υ | NS | Υ | Υ | Υ  | Υ | Υ |
|----------|-------------------|---|----|---|---|----|---|---|
|          | 4 Channel         | Υ | NR | Υ | Υ | NS | Υ | Υ |
| Off-chip | PCI<br>Controller | Υ | NS | Υ | Υ | Υ  | Υ | Υ |
|          | PCI Express       | Υ | Υ  | Υ | Υ | Υ  | - | Υ |
|          | QUICC<br>Engine   | Υ | Υ  | Υ | Υ | Υ  | Υ | - |

**NOTE:** On-chip target configuration registers include I<sup>2</sup>C data register.

**NOTE:** On-chip Ethernet captive resource. Not available to external masters.

**NOTE:** On-chip 4-channel controller can serve external masters.

#### 13.5.1 Unusual DMA scenarios

The following is a description of unusual DMA paths including explanations of why some functional modules cannot serve as DMA targets.

The following topics are addressed:

- DMA transaction initiators (masters)
- DMA targets, that is, data sources or destinations
- Transparency of the bus controllers to DMA transactions
- What is useful as opposed to what is possible. For example, any register can be addressed through an internal control bus, which means configuration and control registers can be DMA targets.

### 13.5.1.1 DMA to core

The L1 cache cannot be a direct DMA target because it cannot be directly addressed by software.

However, DMA access into the L1 cache occurs indirectly if a block of memory that is cached in the L1 is specified as the DMA target. This effect is deterministic if the target memory block was locked into the L1 with cache locking instructions.

### 13.5.1.2 DMA to QUICC Engine block

The QUICC Engine block's dual port RAM (Multi-User-RAM) can serve as both a source and destination for general-purpose DMA transfers.

#### **DMA** system considerations

However, because the QUICC Engine block has its own dedicated DMA controller, using an external DMA controller to access the multi-user\_RAM makes little sense except in special circumstances (such as, possibly, during system initialization).

### 13.5.1.3 DMA to configuration, control, and status registers (CCSR)

Because any internal register can be addressed with the four-channel DMA controller, configuration, control, and status registers throughout the device are valid DMA targets.

However, the primary purpose of DMA, to reduce processor load by moving large blocks of data, is not served by DMA transfers of configuration data. For example, while it is possible to DMA into the I<sup>2</sup>C controller or programmable interrupt controller (PIC), doing so is extremely inefficient and is seldom beneficial in normal operation. The overhead of creating DMA descriptors far exceeds any savings in CPU cycles.

### 13.5.1.4 DMA to I<sup>2</sup>C

The I<sup>2</sup>C controller is not transparent to DMA transfers.

Observe the caveats listed in DMA to configuration, control, and status registers (CCSR) when accessing any I<sup>2</sup>C register, including the data register (I2CDR).

#### 13.5.1.5 DMA to DUART

The DUART provides complete and sophisticated DMA support, which is described in FIFO Mode.

# **Chapter 14 PCI Express Interface Controller**

The PCI Express controller provides the mechanism to communicate with PCI Express devices.

### 14.1 Introduction

The PCI Express controller provides the mechanism to communicate with PCI Express devices.

The PCI Express interface is compatible with the *PCI Express*<sup>TM</sup> *Base Specification*, *Revision 1.0a* (available at http://www.pcisig.org). It is beyond the scope of this manual to document the intricacies of the PCI Express protocol. This chapter describes the PCI Express controller of this device and provides a basic description of the PCI Express protocol. The specific emphasis is directed at how the device implements the PCI Express specification. Designers of systems incorporating PCI Express devices should refer to the specification for a thorough description of PCI Express.

#### NOTE

Much of the available PCI Express literature refers to a 16-bit quantity as a WORD and a 32-bit quantity as a DWORD. Note that this is inconsistent with the terminology in the rest of this manual where the terms 'word' and 'double word' refer to a 32-bit and 64-bit quantity, respectively. Where necessary to avoid confusion, the precise number of bits or bytes is specified.

The PCI Express controller connects the internal platform to a 2.5-GHz serial interface. The device offers one or two PCI Express interfaces with up to x4 link width.

Notes are included to indicate variations for multiple instantiations.

#### Introduction

As both an initiator and a target device, the PCI Express interface is capable of high-bandwidth data transfer and is designed to support next generation I/O devices. Upon coming out of reset, the PCI Express interface performs link width negotiation and exchanges flow control credits with its link partner. Once link autonegotiation is successful, the controller is in operation.

Internally, the design contains queues to keep track of inbound and outbound transactions. There is control logic that handles buffer management, bus protocol, transaction spawning and tag generation. In addition, there are memory blocks used to store inbound and outbound data.

The PCI Express controller can be configured to operate as either a PCI Express root complex (RC) or an endpoint (EP) device. An RC device connects the host CPU/memory subsystem to I/O devices while an EP device typically denotes a peripheral or I/O device. In RC mode, a PCI Express type 1 configuration header is used; in EP mode, a PCI Express type 0 configuration header is used.

This figure shows a high-level block diagram of the PCI Express controller.



Figure 14-1. PCI Express Controller Block Diagram

As an initiator, the PCI Express controller supports memory read and write operations with a maximum transaction size of 256 bytes. In addition, configuration and I/O transactions are supported if the PCI Express controller is in RC mode. As a target interface, the PCI Express controller accepts read and write operations to local memory space. When configured as an EP device, the PCI Express controller accepts configuration transactions to the internal PCI Express configuration registers. Message generation and acceptance are supported in both RC and EP modes. Locked transactions and inbound I/O transactions are not supported.

### 14.1.1 Outbound transactions

Outbound internal platform transactions to PCI Express are first mapped to a translation window to determine what PCI Express transactions are to be issued.

#### Introduction

A transaction from the internal platform can become a PCI Express Memory, I/O, Message, or Configuration transaction depending on the window attributes.

A transaction may be broken up into smaller sized transactions depending on the original request size, transaction type, and either the PCI Express device control register [MAX\_PAYLOAD\_SIZE] field for write requests or the PCI Express device control register [MAX\_READ\_SIZE] field for read requests. The controller performs PCI Express ordering rule checking to determine which transaction is to be sent on the PCI Express link.

In general, transactions are serviced in the order that they are received from the internal platform. Only when there is a stalled condition does the controller apply PCI Express ordering rules to outstanding transactions. For posted write transactions, once all data has been received from the internal platform, the data is forwarded to the PCI Express link and the transaction is considered as done. For non-posted write transactions, the controller waits for the completion packets to return before considering the transaction finished. For non-posted read transactions, the controller waits for all completion packets to return and then forwards all data back to the internal platform before terminating the transaction.

Note that after reset or when recovering from a link down condition, external transactions should not be attempted until the link has successfully trained. Software can poll the LTSSM state status register (PEX\_LTSSM\_STAT) to check the status of link training before issuing external requests.

### 14.1.2 Inbound transactions

Inbound PCI Express transactions to internal platform are first mapped to a translation window to determine what internal platform transactions are to be issued.

A transaction may be broken up into smaller sized transactions when sending to the internal platform depending on the original request size, byte enables and starting/ending addresses. The controller performs PCI Express ordering rule checking to determine what transaction is to be sent next to the internal platform.

In general, transactions are serviced in the order that they are received from the PCI Express link. Only when there is a stalled condition does the controller apply PCI Express ordering to outstanding transactions. For posted write transactions, once all data has been received from the PCI Express link, the data is forwarded to the internal platform and the transaction is considered as done. For non-posted read transactions, the controller forwards internal platform data back to the PCI Express link.

Note that the controller splits transactions at the crossing of every 256-byte-aligned boundary when sending data back to the PCI Express link.

## 14.2 PCI Express features summary

The following is a list of features supported by the PCI Express controller:

- Compatible with the PCI Express Base Specification, Revision 1.0a
- Supports root complex (RC) and endpoint (EP) configurations
- 32- and 64-bit PCI Express address support
- 36-bit internal platform address support
- x4, x2, or x1 link support
- Supports accesses to all PCI Express memory and I/O address spaces (requestor only)
- Supports posting of processor-to-PCI Express and PCI Express-to-memory writes
- Supports strong and relaxed transaction ordering rules
- Enforces outbound PCI Express ordering rules and inbound internal platform priority
- PCI Express configuration registers (type 0 in EP mode, type 1 in RC mode)
- Baseline and advanced error reporting support
- One virtual channel (VC0)
- 256-byte maximum payload size (MAX\_PAYLOAD\_SIZE)
- Supports three inbound general-purpose translation windows and one configuration window
- Supports four outbound translation windows and one default window
- Supports eight non-posted and four posted PCI Express inbound transactions
- Supports up to six internal platform reads and eight internal platform writes for outbound transaction. (The maximum number of outstanding transactions at any given time is eight.)
- Credit-based flow control management
- Supports PCI Express messages and interrupts
- Accepts up to 256-byte transactions from the internal platform

# 14.3 PCI Express modes of operation

Several parameters that affect the PCI Express controller's modes of operation are determined at power-on reset (POR) by reset configuration signals as described in the following table.

#### PCI Express signal descriptions

Table 14-1. POR parameters for PCI Express controller

| Reset configuration signals | Description                                               |
|-----------------------------|-----------------------------------------------------------|
| Host/Agent Configuration    | Selects between root complex (RC) and endpoint (EP) modes |
| cfg_host_agt[0:2]           |                                                           |
| I/O Port Selection          | Selects the width of the PCI Express link                 |
| cfg_io_ports[0:3]           |                                                           |

## 14.3.1 Root complex/endpoint modes

The PCI Express controller can function as either a root complex (RC) or an endpoint (EP) on the PCI Express link.

The host/agent configuration input signals cfg\_host\_agt[0:2] multiplexed on LWE\_B[1]/ LA[18:19] determine the RC/EP mode.

#### 14.3.2 Link width

The I/O port selection configuration input signals cfg\_IO\_ports[0:3], multiplexed on TSEC1\_TXD[3:1], and CFG\_IO\_PORTS3 determine the initial link width. (See I/O port selection.)

See Minimum frequency requirements, for proper selection of CCB clock frequency with regard to PCI Express link width selection.

# 14.4 PCI Express signal descriptions

This topic describes the signals of the PCI Express controller.

PCI Express defines the connection between two devices as a link, which can be composed of a single or multiple lanes. Each lane consists of a differential pair for transmitting (SD\_TX and SD\_TX\_B) and a differential pair for receiving (SD\_RX and SD\_RX\_B) with an embedded data clock.

Although the generic PCI Express controller described here accommodates up to a single x4 link, there are two PCI Express controllers instantiated on this device. For specific pin muxing details, see I/O port selection.

This table contains detailed descriptions of the external PCI Express interface signals.

Table 14-2. PCI Express interface signals-Detailed signal descriptions

| Signal       | I/O |                                                                              | Description                                                                                                                                                                                            |  |  |  |  |  |
|--------------|-----|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SD_RX[3:0]   | I   | Receive da                                                                   | ta. The receive data signals carry PCI Express packet information.                                                                                                                                     |  |  |  |  |  |
|              |     | described in                                                                 | ng of SerDes lane and PCI Express controller depends on the POR configuration as I/O port selection. Note that lane reversal may affect the logical lane assignment. ne reversal for more information. |  |  |  |  |  |
|              |     | State<br>Meaning                                                             | Asserted/Negated-PCI Express interface.                                                                                                                                                                |  |  |  |  |  |
|              |     | Timing                                                                       | ssertion/Negation-As described in the <i>PCI Express Base Specification, Revision 0a</i> .                                                                                                             |  |  |  |  |  |
| SD_RX_B[3:0] | I   | Receive da<br>( SD_RX[3:                                                     | ta, inverted. SD_RX_B[3:0] are the inverted forms of the receive data signals 0]).                                                                                                                     |  |  |  |  |  |
|              |     | State<br>Meaning                                                             | Asserted/Negated-Represents the inverse of data being received from the PCI Express interface.                                                                                                         |  |  |  |  |  |
|              |     | Timing                                                                       | Assertion/Negation-As described in the PCI Express Base Specification, Revision 1.0a.                                                                                                                  |  |  |  |  |  |
| SD_TX[3:0]   | 0   | Transmit da                                                                  | tta. The transmit data signals carry PCI Express packet information.                                                                                                                                   |  |  |  |  |  |
|              |     | described in                                                                 | ng of SerDes lane and PCI Express controller depends on the POR configuration as I/O port selection. Note that lane reversal may affect the logical lane assignment. we reversal for more information. |  |  |  |  |  |
|              |     | State<br>Meaning                                                             | Asserted/Negated-Represents data being transmitted to the PCI Express interface.                                                                                                                       |  |  |  |  |  |
|              |     | Timing                                                                       | Assertion/Negation-As described in the PCI Express Base Specification, Revision 1.0a.                                                                                                                  |  |  |  |  |  |
| SD_TX_B[3:0] | 0   | Transmit data, inverted. are the inverted form of the transmit data signals. |                                                                                                                                                                                                        |  |  |  |  |  |
|              |     | State<br>Meaning                                                             | Asserted/Negated-Represents the inverse of data being transmitted to the PCI Express interface.                                                                                                        |  |  |  |  |  |
|              |     | Timing                                                                       | Assertion/Negation-As described in the PCI Express Base Specification, Revision 1.0a.                                                                                                                  |  |  |  |  |  |

# 14.5 Memory map/register overview

The PCI Express interface supports the following register types:

- Memory-mapped registers-these registers control PCI Express address translation, PCI error management, and PCI Express configuration register access. These registers are described in the sections below.
- PCI Express configuration registers contained within the PCI Express configuration space-these registers are specified by the PCI Express specification for every PCI Express device. These registers are described in PCI Express configuration space access and its subsections.

# 14.6 PCI Express memory-mapped registers

The PCI Express memory mapped registers are accessed by reading and writing to an address comprised of the base address (specified in the CCSRBAR on the local side or the PEXCSRBAR on the PCI Express side) plus the block base address, plus the offset of the specific register to be accessed. Note that all memory-mapped registers (except the PCI Express configuration data register, PEX\_CONFIG\_DATA) must only be accessed as 32-bit quantities.

Also note that although the table explicitly lists only the registers for the PCI Express controller 1, the register map for PCI Express controller 2 is the same except for the block base address. Memory-mapped registers for PCI Express controller 1 begin at block base address 0x0\_A000 and controller 2 registers begin at 0x0\_9000.

#### PEX memory map

| Offset address (hex) | Register name                                                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|----------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 9000                 | PCI Express configuration address register (PEX2_PEX_CONFIG_ADDR)          | 32                 | R/W    | 0000_0000h  | 14.6.1/739       |
| 9004                 | PCI Express configuration data register (PEX2_PEX_CONFIG_DATA)             | 32                 | R/W    | 0000_0000h  | 14.6.2/740       |
| 900C                 | PCI Express outbound completion timeout register (PEX2_PEX_OTB_CPL_TOR)    | 32                 | R/W    | 0010_FFFFh  | 14.6.3/740       |
| 9010                 | PCI Express configuration retry timeout register (PEX2_PEX_CONF_RTY_TOR)   | 32                 | R/W    | 0400_FFFFh  | 14.6.4/741       |
| 9014                 | PCI Express configuration register (PEX2_PEX_CONFIG)                       | 32                 | R/W    | 0000_0000h  | 14.6.5/742       |
| 9020                 | PCI Express PME & message detect register (PEX2_PEX_PME_MES_DR)            | 32                 | w1c    | 0000_0000h  | 14.6.6/743       |
| 9024                 | PCI Express PME & message disable register (PEX2_PEX_PME_MES_DISR)         | 32                 | R/W    | 0000_0000h  | 14.6.7/746       |
| 9028                 | PCI Express PME & message interrupt enable register (PEX2_PEX_PME_MES_IER) | 32                 | R/W    | 0000_0000h  | 14.6.8/748       |
| 902C                 | PCI Express power management command register (PEX2_PEX_PMCR)              | 32                 | R/W    | 0000_0000h  | 14.6.9/750       |
| 9BF8                 | IP block revision register 1 (PEX2_PEX_IP_BLK_REV1)                        | 32                 | R      | 0208_0100h  | 14.6.10/<br>751  |
| 9BFC                 | IP block revision register 2 (PEX2_PEX_IP_BLK_REV2)                        | 32                 | R      | 0000_0000h  | 14.6.11/<br>751  |
| 9C00                 | PCI Express outbound translation address register n (PEX2_PEXOTAR0)        | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |

| Offset<br>address<br>(hex) | Register name                                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 9C04                       | PCI Express outbound translation extended address register n (PEX2_PEXOTEAR0) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| 9C10                       | PCI Express outbound window attributes register n (PEX2_PEXOWAR0)             | 32                 | R/W    | 8004_4023h  | 14.6.14/<br>754  |
| 9C20                       | PCI Express outbound translation address register n (PEX2_PEXOTAR1)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| 9C24                       | PCI Express outbound translation extended address register n (PEX2_PEXOTEAR1) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| 9C28                       | PCI Express outbound window base address register n (PEX2_PEXOWBAR1)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| 9C30                       | PCI Express outbound window attributes register n (PEX2_PEXOWAR1)             | 32                 | R/W    | 0004_4023h  | 14.6.16/<br>757  |
| 9C40                       | PCI Express outbound translation address register n (PEX2_PEXOTAR2)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| 9C44                       | PCI Express outbound translation extended address register n (PEX2_PEXOTEAR2) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| 9C48                       | PCI Express outbound window base address register n (PEX2_PEXOWBAR2)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| 9C50                       | PCI Express outbound window attributes register n (PEX2_PEXOWAR2)             | 32                 | R/W    | 0004_4023h  | 14.6.16/<br>757  |
| 9C60                       | PCI Express outbound translation address register n (PEX2_PEXOTAR3)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| 9C64                       | PCI Express outbound translation extended address register n (PEX2_PEXOTEAR3) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| 9C68                       | PCI Express outbound window base address register n (PEX2_PEXOWBAR3)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| 9C70                       | PCI Express outbound window attributes register 3 (PEX2_PEXOWAR3)             | 32                 | R/W    | 0000_0000h  | 14.6.17/<br>760  |
| 9C80                       | PCI Express outbound translation address register n (PEX2_PEXOTAR4)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| 9C84                       | PCI Express outbound translation extended address register n (PEX2_PEXOTEAR4) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| 9C88                       | PCI Express outbound window base address register n (PEX2_PEXOWBAR4)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| 9C90                       | PCI Express outbound window attributes register 4 (PEX2_PEXOWAR4)             | 32                 | R/W    | 0004_4023h  | 14.6.18/<br>762  |
| 9DA0                       | PCI Express inbound translation address register n (PEX2_PEXITAR3)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| 9DA8                       | PCI Express inbound window base address register n (PEX2_PEXIWBAR3)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| 9DAC                       | PCI Express inbound window base extended address register n (PEX2_PEXIWBEAR3) | 32                 | R/W    | 0000_0000h  | 14.6.21/<br>766  |
| 9DB0                       | PCI Express inbound window attributes register n (PEX2_PEXIWAR3)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |

| Offset<br>address<br>(hex) | Register name                                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 9DC0                       | PCI Express inbound translation address register n (PEX2_PEXITAR2)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| 9DC8                       | PCI Express inbound window base address register n (PEX2_PEXIWBAR2)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| 9DCC                       | PCI Express inbound window base extended address register n (PEX2_PEXIWBEAR2) | 32                 | R/W    | 0000_0000h  | 14.6.21/<br>766  |
| 9DD0                       | PCI Express inbound window attributes register n (PEX2_PEXIWAR2)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |
| 9DE0                       | PCI Express inbound translation address register n (PEX2_PEXITAR1)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| 9DE8                       | PCI Express inbound window base address register n (PEX2_PEXIWBAR1)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| 9DF0                       | PCI Express inbound window attributes register n (PEX2_PEXIWAR1)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |
| 9E00                       | PCI Express error detect register (PEX2_PEX_ERR_DR)                           | 32                 | w1c    | 0000_0000h  | 14.6.23/<br>770  |
| 9E08                       | PCI Express error interrupt enable register (PEX2_PEX_ERR_EN)                 | 32                 | R/W    | 0000_0000h  | 14.6.24/<br>773  |
| 9E10                       | PCI Express error disable register (PEX2_PEX_ERR_DISR)                        | 32                 | R/W    | 0000_0000h  | 14.6.25/<br>776  |
| 9E20                       | PCI Express error capture status register (PEX2_PEX_ERR_CAP_STAT)             | 32                 | R/W    | 0000_0000h  | 14.6.26/<br>778  |
| 9E28                       | PCI Express error capture register n (PEX2_PEX_ERR_CAP_R0)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| 9E2C                       | PCI Express error capture register n (PEX2_PEX_ERR_CAP_R1)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| 9E30                       | PCI Express error capture register n (PEX2_PEX_ERR_CAP_R2)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| 9E34                       | PCI Express error capture register n (PEX2_PEX_ERR_CAP_R3)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| A000                       | PCI Express configuration address register (PEX1_PEX_CONFIG_ADDR)             | 32                 | R/W    | 0000_0000h  | 14.6.1/739       |
| A004                       | PCI Express configuration data register (PEX1_PEX_CONFIG_DATA)                | 32                 | R/W    | 0000_0000h  | 14.6.2/740       |
| A00C                       | PCI Express outbound completion timeout register (PEX1_PEX_OTB_CPL_TOR)       | 32                 | R/W    | 0010_FFFFh  | 14.6.3/740       |
| A010                       | PCI Express configuration retry timeout register (PEX1_PEX_CONF_RTY_TOR)      | 32                 | R/W    | 0400_FFFFh  | 14.6.4/741       |
| A014                       | PCI Express configuration register (PEX1_PEX_CONFIG)                          | 32                 | R/W    | 0000_0000h  | 14.6.5/742       |
| A020                       | PCI Express PME & message detect register (PEX1_PEX_PME_MES_DR)               | 32                 | w1c    | 0000_0000h  | 14.6.6/743       |
| A024                       | PCI Express PME & message disable register (PEX1_PEX_PME_MES_DISR)            | 32                 | R/W    | 0000_0000h  | 14.6.7/746       |

| Offset<br>address<br>(hex) | Register name                                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| A028                       | PCI Express PME & message interrupt enable register (PEX1_PEX_PME_MES_IER)    | 32                 | R/W    | 0000_0000h  | 14.6.8/748       |
| A02C                       | PCI Express power management command register (PEX1_PEX_PMCR)                 | 32                 | R/W    | 0000_0000h  | 14.6.9/750       |
| ABF8                       | IP block revision register 1 (PEX1_PEX_IP_BLK_REV1)                           | 32                 | R      | 0208_0100h  | 14.6.10/<br>751  |
| ABFC                       | IP block revision register 2 (PEX1_PEX_IP_BLK_REV2)                           | 32                 | R      | 0000_0000h  | 14.6.11/<br>751  |
| AC00                       | PCI Express outbound translation address register n (PEX1_PEXOTAR0)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| AC04                       | PCI Express outbound translation extended address register n (PEX1_PEXOTEAR0) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| AC10                       | PCI Express outbound window attributes register n (PEX1_PEXOWAR0)             | 32                 | R/W    | 8004_4023h  | 14.6.14/<br>754  |
| AC20                       | PCI Express outbound translation address register n (PEX1_PEXOTAR1)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| AC24                       | PCI Express outbound translation extended address register n (PEX1_PEXOTEAR1) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| AC28                       | PCI Express outbound window base address register n (PEX1_PEXOWBAR1)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| AC30                       | PCI Express outbound window attributes register n (PEX1_PEXOWAR1)             | 32                 | R/W    | 0004_4023h  | 14.6.16/<br>757  |
| AC40                       | PCI Express outbound translation address register n (PEX1_PEXOTAR2)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| AC44                       | PCI Express outbound translation extended address register n (PEX1_PEXOTEAR2) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| AC48                       | PCI Express outbound window base address register n (PEX1_PEXOWBAR2)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| AC50                       | PCI Express outbound window attributes register n (PEX1_PEXOWAR2)             | 32                 | R/W    | 0004_4023h  | 14.6.16/<br>757  |
| AC60                       | PCI Express outbound translation address register n (PEX1_PEXOTAR3)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| AC64                       | PCI Express outbound translation extended address register n (PEX1_PEXOTEAR3) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| AC68                       | PCI Express outbound window base address register n (PEX1_PEXOWBAR3)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |
| AC70                       | PCI Express outbound window attributes register 3 (PEX1_PEXOWAR3)             | 32                 | R/W    | 0000_0000h  | 14.6.17/<br>760  |
| AC80                       | PCI Express outbound translation address register n (PEX1_PEXOTAR4)           | 32                 | R/W    | 0000_0000h  | 14.6.12/<br>752  |
| AC84                       | PCI Express outbound translation extended address register n (PEX1_PEXOTEAR4) | 32                 | R/W    | 0000_0000h  | 14.6.13/<br>752  |
| AC88                       | PCI Express outbound window base address register n (PEX1_PEXOWBAR4)          | 32                 | R/W    | 0000_0000h  | 14.6.15/<br>756  |

| Offset address (hex) | Register name                                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| AC90                 | PCI Express outbound window attributes register 4 (PEX1_PEXOWAR4)             | 32                 | R/W    | 0004_4023h  | 14.6.18/<br>762  |
| ADA0                 | PCI Express inbound translation address register n (PEX1_PEXITAR3)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| ADA8                 | PCI Express inbound window base address register n (PEX1_PEXIWBAR3)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| ADAC                 | PCI Express inbound window base extended address register n (PEX1_PEXIWBEAR3) | 32                 | R/W    | 0000_0000h  | 14.6.21/<br>766  |
| ADB0                 | PCI Express inbound window attributes register n (PEX1_PEXIWAR3)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |
| ADC0                 | PCI Express inbound translation address register n (PEX1_PEXITAR2)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| ADC8                 | PCI Express inbound window base address register n (PEX1_PEXIWBAR2)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| ADCC                 | PCI Express inbound window base extended address register n (PEX1_PEXIWBEAR2) | 32                 | R/W    | 0000_0000h  | 14.6.21/<br>766  |
| ADD0                 | PCI Express inbound window attributes register n (PEX1_PEXIWAR2)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |
| ADE0                 | PCI Express inbound translation address register n (PEX1_PEXITAR1)            | 32                 | R/W    | 0000_0000h  | 14.6.19/<br>764  |
| ADE8                 | PCI Express inbound window base address register n (PEX1_PEXIWBAR1)           | 32                 | R/W    | 0000_0000h  | 14.6.20/<br>765  |
| ADF0                 | PCI Express inbound window attributes register n (PEX1_PEXIWAR1)              | 32                 | R/W    | 20F4_4023h  | 14.6.22/<br>767  |
| AE00                 | PCI Express error detect register (PEX1_PEX_ERR_DR)                           | 32                 | w1c    | 0000_0000h  | 14.6.23/<br>770  |
| AE08                 | PCI Express error interrupt enable register (PEX1_PEX_ERR_EN)                 | 32                 | R/W    | 0000_0000h  | 14.6.24/<br>773  |
| AE10                 | PCI Express error disable register (PEX1_PEX_ERR_DISR)                        | 32                 | R/W    | 0000_0000h  | 14.6.25/<br>776  |
| AE20                 | PCI Express error capture status register (PEX1_PEX_ERR_CAP_STAT)             | 32                 | R/W    | 0000_0000h  | 14.6.26/<br>778  |
| AE28                 | PCI Express error capture register n (PEX1_PEX_ERR_CAP_R0)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| AE2C                 | PCI Express error capture register n (PEX1_PEX_ERR_CAP_R1)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| AE30                 | PCI Express error capture register n (PEX1_PEX_ERR_CAP_R2)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |
| AE34                 | PCI Express error capture register n (PEX1_PEX_ERR_CAP_R3)                    | 32                 | R/W    | 0000_0000h  | 14.6.27/<br>779  |

# 14.6.1 PCI Express configuration address register (PEXx\_PEX\_CONFIG\_ADDR)

The PCI Express configuration address register contains address information for accesses to PCI Express internal and external configuration registers.

Both root complex (RC) and endpoint (EP) configuration headers contain 4096 bytes of address space. To access a register within the header, both the extended register number and the register number fields are concatenated to form the 4-byte aligned address of the register. That is, the register address is extended to register number 0b00.





#### PEXx\_PEX\_CONFIG\_ADDR field descriptions

| Field          | Description                                                                                                                                                                                                     |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EN        | Enable. This bit allows a PCI Express configuration access when PEX_CONFIG_DATA is accessed. If this bit is cleared, writing to PEX_CONFIG_DATA has no effect and reading PEX_CONFIG_DATA returns unknown data. |
| 1–3<br>-       | This field is reserved. Reserved                                                                                                                                                                                |
| 4–7<br>EXTREGN | Extended register number. This field allows access to extended PCI Express configuration space (that is, the registers in the offset range from 0x100 to 0xFFF).                                                |
| 8–15<br>BUSN   | Bus number. PCI bus number to access                                                                                                                                                                            |
| 16–20<br>DEVN  | Device number. Device number to access on specified bus                                                                                                                                                         |
| 21–23<br>FUNCN | Function number. Function to access within specified device                                                                                                                                                     |
| 24–29<br>REGN  | Register number. 32-bit register to access within specified device                                                                                                                                              |
| 30–31<br>-     | This field is reserved. Reserved                                                                                                                                                                                |

# 14.6.2 PCI Express configuration data register (PEXx\_PEX\_CONFIG\_DATA)

The PCI Express configuration data register is a 32-bit port for internal and external configuration access. Note that accesses of 1, 2, or 4 bytes to the PCI Express configuration data register are allowed. Also note that accesses to the little-endian PCI Express configuration space must be properly formatted. See Byte order for configuration transactions for more information.





#### PEXx\_PEX\_CONFIG\_DATA field descriptions

| Field | Description                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|       | A read or write to this register starts a PCI Express configuration cycle if the PEX_CONFIG_ADDR enable bit is set (PEX_CONFIG_ADDR[EN] = 1). |

# 14.6.3 PCI Express outbound completion timeout register (PEXx\_PEX\_OTB\_CPL\_TOR)

The PCI Express outbound completion timeout register contains the maximum wait time for a response to come back as a result of an outbound non-posted request before a timeout condition occurs.

Address: Base address + Ch offset



### PEXx\_PEX\_OTB\_CPL\_TOR field descriptions

| Field | Description                                                                                                                   |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------|--|
| 0     | Timeout disable. This bit controls the enabling/disabling of the timeout function.                                            |  |
| TD    | <ul><li>0 Enable completion timeout</li><li>1 Disable completion timeout</li></ul>                                            |  |
| 1–7   | This field is reserved. Reserved                                                                                              |  |
| 8–31  | Timeout counter. This is the value that is used to load the response counter of the completion timeout.                       |  |
| TC    | One TC unit is 8x the PCI Express controller clock period; that is, one TC unit is 20 ns at 400 MHz, and 30 ns at 266.66 MHz. |  |
|       | The following are examples of timeout periods based on different TC settings:                                                 |  |
|       | 0x00_0000 Reserved                                                                                                            |  |
|       | 0x10_FFFF 22.28 ms at 400 MHz controller clock; 33.34 ms at 266.66 MHz controller clock                                       |  |
|       | 0xFF_FFFF 335.54 ms at 400 MHz controller clock; 503.31 ms at 266.66 MHz controller clock                                     |  |

# 14.6.4 PCI Express configuration retry timeout register (PEXx\_PEX\_CONF\_RTY\_TOR)

The PCI Express configuration retry timeout register contains the maximum time period during which retries of configuration transactions which resulted in a CRS response occur.

Address: Base address + 10h offset



#### PEXx\_PEX\_CONF\_RTY\_TOR field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                            |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RD  | Retry disable. This bit disables the retry of a configuration transaction that receives a CRS status response packet.                                                                                                                                                                                  |
|          | <ul> <li>Enable retry of a configuration transaction in response to receiving a CRS status response until the timeout counter (defined by the PEX_CONF_RTY_TOR[TC] field) has expired.</li> <li>Disable retry of a configuration transaction regardless of receiving a CRS status response.</li> </ul> |
| 1–3<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                       |

### PEXx\_PEX\_CONF\_RTY\_TOR field descriptions (continued)

| Field | Description                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------|
| 4–31  | Timeout counter. This is the value that is used to load the CRS response counter.                                            |
| TC    | One TC unit is 8x the PCI Express controller clock period; that is, one TC unit is 20 ns at 400 MHz and 30 ns at 266.66 MHz. |
|       | Timeout period based on different TC settings:                                                                               |
|       | 0x000_0000 Reserved                                                                                                          |
|       | 0x400_FFFF 1.34 s at 400 MHz controller clock, 2.02 s at 266.66 MHz controller clock                                         |
|       | 0xFFF_FFFF 5.37 s at 400 MHz controller clock, 8.05 s at 266.66 MHz controller clock                                         |

## 14.6.5 PCI Express configuration register (PEXx\_PEX\_CONFIG)

The PCI Express configuration register contains various control switches for the controller.





### PEXx\_PEX\_CONFIG field descriptions

| Field      | Description                                                                                                                                                                                                                                                 |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–26<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                            |
| 27<br>SAC  | Sense ASPM Control. This bit controls the default value of ASPM of PEX Link Control Register's bit 0. See PCI Express Link Control Register (Link_Control_Register) for more information.  NOTE: This device does not support the PCI Express ASPM feature. |
| 28–29<br>- | This field is reserved. Reserved                                                                                                                                                                                                                            |
| 30<br>SP   | Slot Present. This bit controls the default value of the PCI Express capabilities register [slot] bit. See PCI Express Capabilities Register (Capabilities_Register) for more information.                                                                  |
| 31<br>SCC  | Slot Clock Configuration. This bit controls the default value of the PCI Express link status register [SCC] bit. See PCI Express Link Status Register (Link_Status_Register) for more information.                                                          |

# 14.6.6 PCI Express PME & message detect register (PEXx\_PEX\_PME\_MES\_DR)

The PCI Express PME and message detect register logs inbound messages and PME events that are detected by the PCI Express controller. This register is a write-1-to-clear type register.



## PEXx\_PEX\_PME\_MES\_DR field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                             |
| 16<br>PTO   | PME turn off. This bit indicates the detection of a PME_Turn_Off message. This bit is only valid in EP mode.                                                                                                                                                                                                                                                 |
|             | A PME_Turn_Off_message is detected     No PME_Turn_Off message detected                                                                                                                                                                                                                                                                                      |
| 17<br>-     | This field is reserved.  Reserved. Note that during normal operation, this bit may be set (falsely). The bit may be ignored and cleared (w1c) without consequence.                                                                                                                                                                                           |
| 18<br>ENL23 | Entered L2/L3 ready state. This bit indicates that the PCI Express controller has entered L2/L3 state. This is only valid in RC mode.                                                                                                                                                                                                                        |
|             | <ul><li>1 L2/L3 ready state has been entered</li><li>0 L2/L3 ready state has not been entered</li></ul>                                                                                                                                                                                                                                                      |
| 19<br>EXL23 | Exit L2/L3 ready state. This bit indicates that the PCI Express controller has exited the L2/L3 state. This is only valid in RC mode.                                                                                                                                                                                                                        |
|             | <ul><li>1 Exit L2/L3 state has been detected</li><li>0 Exit L2/L3 state not detected</li></ul>                                                                                                                                                                                                                                                               |
| 20 -        | This field is reserved.  Reserved. Note that during normal operation, this bit may be set (falsely). The bit may be ignored and cleared (w1c) without consequence.                                                                                                                                                                                           |
| 21<br>HRD   | Hot reset detected. This bit indicates that the PCI Express controller has detected a hot reset condition on the link. The controller is reset and cleans up all outstanding transactions. Link retraining takes place once hot reset state is exited. This is valid only in EP mode.                                                                        |
|             | <ul><li>1 Hot reset request has been detected</li><li>0 Hot reset request not detected</li></ul>                                                                                                                                                                                                                                                             |
| 22<br>LDD   | Link down detected. This bit indicates that a link down condition has been detected. The controller is reset and then cleans up all outstanding transactions. Link retraining takes place once the controller has cleaned itself up. Note that for EP, this bit and HRD are typically set when a hot reset event is detected.  1 Link down has been detected |
|             | 0 Link down not detected                                                                                                                                                                                                                                                                                                                                     |
| 23–24       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                             |
| 25<br>AION  | Attention indicator on. This bit indicates the detection of an Attention_Indicator_On message. This bit is only valid in EP mode.                                                                                                                                                                                                                            |
|             | Attention indicator on message is detected     No attention indicator on message detected                                                                                                                                                                                                                                                                    |
| 26<br>AIB   | Attention indicator blink. This bit indicates the detection of an Attention_Indicator_Blink message. This bit is only valid in EP mode.                                                                                                                                                                                                                      |
|             | <ul><li>1 Attention indicator blink message is detected</li><li>0 No attention indicator blink message detected</li></ul>                                                                                                                                                                                                                                    |
| 27<br>AIOF  | Attention indicator off. This bit indicates the detection of an Attention_Indicator_Off message. This bit is only valid in EP mode.                                                                                                                                                                                                                          |

# PEXx\_PEX\_PME\_MES\_DR field descriptions (continued)

| Field      | Description                                                                                                                           |
|------------|---------------------------------------------------------------------------------------------------------------------------------------|
|            | 1 Attention indicator off message is detected                                                                                         |
|            | 0 No attention indicator off message detected                                                                                         |
| 28<br>PION | Power indicator on. This bit indicates the detection of a Power_Indicator_On message. This bit is only valid in EP mode.              |
|            | 1 Power indicator on message is detected                                                                                              |
|            | 0 No power indicator on message detected                                                                                              |
| 29<br>PIB  | Power indicator blink. This bit indicates the detection of an Power_Indicator_Blink message. This bit is only valid in EP mode.       |
|            | 1 Power indicator blink message is detected                                                                                           |
|            | 0 No power indicator blink message detected                                                                                           |
| 30<br>PIOF | Power indicator off. This bit indicates the detection of an Power_Indicator_Off message. This bit is only valid in EP mode.           |
|            | Power indicator off message is detected                                                                                               |
|            | 0 No power indicator off message detected                                                                                             |
| 31<br>ABP  | Attention button pressed. This bit indicates the detection of an Attention_Button_Pressed message. This bit is only valid in RC mode. |
|            | 1 Attention button press message is detected                                                                                          |
|            | 0 No attention button press message detected                                                                                          |

# 14.6.7 PCI Express PME & message disable register (PEXx\_PEX\_PME\_MES\_DISR)

The PCI Express PME and message disable register when set, prevents the detection of the corresponding bits in the PCI Express PME and message detect register.



PEXx\_PEX\_PME\_MES\_DISR field descriptions

| Field        | Description                                                                                                                                                                                     |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–15<br>-    | This field is reserved. Reserved                                                                                                                                                                |  |
| 16<br>PTOD   | PME turn off disable. When set, this bit disables the setting of PEX_PME_MES_DR[PTO] bit.  1 Disable PME_Turn_Off_message detection  0 Enable PME_Turn_Off message detection                    |  |
| 17<br>-      | This field is reserved. Reserved                                                                                                                                                                |  |
| 18<br>ENL23D | Entered_L2/L3 ready disable. When set, this bit disables the setting of PEX_PME_MES_DR[ENL23] bit.  1 Disable Entered_L2/L3 ready state detection  0 Enable Entered_L2/L3 ready state detection |  |

## PEXx\_PEX\_PME\_MES\_DISR field descriptions (continued)

| Field        | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| 19<br>EXL23D | Exited_L2/L3 ready disable. When set, this bit disables the setting of PEX_PME_MES_DR[EXL23] bit.              |
|              | <ul><li>Disable Exited_L2/L3 ready state detection</li><li>Enable Exited_L2/L3 ready state detection</li></ul> |
| 20           | This field is reserved.                                                                                        |
| -            | Reserved                                                                                                       |
| 21<br>HRDD   | Hot reset detected disable. When set, this bit disables the setting of PEX_PME_MES_DR[HRD] bit.                |
|              | 1 Disable hot reset state detection                                                                            |
|              | 0 Enable hot reset state detection                                                                             |
| 22<br>LDDD   | Link down detected disable. When set, this bit disables the setting of PEX_PME_MES_DR[LDD] bit.                |
|              | 1 Disable link down state detection                                                                            |
|              | 0 Enable link down state detection                                                                             |
| 23–24        | This field is reserved. Reserved                                                                               |
| 25<br>AIOND  | Attention indicator on disable. When set, this bit disables the setting of PEX_PME_MES_DR[AION] bit.           |
| AIOND        | 1 Disable attention indicator on message detection                                                             |
|              | 0 Enable attention indicator on message detection                                                              |
| 26<br>AIBD   | Attention indicator blink disable. When set, this bit disables the setting of PEX_PME_MES_DR[AIB] bit.         |
|              | 1 Disable attention indicator blink message detection                                                          |
|              | 0 Enable attention indicator blink message detection                                                           |
| 27<br>AIOFD  | Attention indicator off disable. When set, this bit disables the setting of PEX_PME_MES_DR[AIOF] bit.          |
|              | 1 Disable attention indicator off message detection                                                            |
|              | 0 Enable attention indicator off message detection                                                             |
| 28<br>PIOND  | Power indicator on disable. When set, this bit disables the setting of PEX_PME_MES_DR[PION] bit.               |
|              | 1 Disable power indicator on message detection                                                                 |
|              | 0 Enable power indicator on message detection                                                                  |
| 29<br>PIBD   | Power indicator blink disable. When set, this bit disables the setting of PEX_PME_MES_DR[PIB] bit.             |
|              | 1 Disable power indicator blink message detection                                                              |
|              | 0 Enable power indicator blink message detection                                                               |
| 30<br>PIOFD  | Power indicator off disable. When set, this bit disables the setting of PEX_PME_MES_DR[PIOF] bit.              |
|              | 1 Disable power indicator off message detection                                                                |
|              | 0 Enable power indicator off message detection                                                                 |
| 31<br>ABPD   | Attention button pressed disable. When set, this bit disables the setting of PEX_PME_MES_DR[ABP] bit.          |
|              | 1 Disable attention button press message detection                                                             |
|              | 0 Enable attention button press message detection                                                              |

# 14.6.8 PCI Express PME & message interrupt enable register (PEXx\_PEX\_PME\_MES\_IER)

The PCI Express PME and message interrupt enable register allows for the detection of a message or a PME event to generate an interrupt, provided that the corresponding bit in the PCI Express PME and message detect register is set.



PEXx\_PEX\_PME\_MES\_IER field descriptions

| Field         | Description                                                                                                                                                                                        |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                                   |  |
| 16<br>PTOIE   | PME turn off interrupt enable. When set and PEX_PME_MES_DR[PTO]=1 generates an interrupt.  1 Enable PME_Turn_Off_message interrupt generation  0 Disable PME_Turn_Off message interrupt generation |  |
| 17<br>-       | This field is reserved. Reserved                                                                                                                                                                   |  |
| 18<br>ENL23IE | Entered L2/L3 ready interrupt enable. When set and PEX_PME_MES_DR[ENL23]=1 generates an interrupt.                                                                                                 |  |

## PEXx\_PEX\_PME\_MES\_IER field descriptions (continued)

| Field         | Description                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------|
|               | 1 Enable Entered_L2/L3 ready state interrupt generation                                                |
|               | 0 Disable Entered_L2/L3 ready state interrupt generation                                               |
| 19<br>EXL23IE | Exited L2/L3 ready interrupt enable. When set and PEX_PME_MES_DR[EXL23]=1 generates an interrupt.      |
|               | 1 Enable Exited_L2/L3 ready state interrupt generation                                                 |
|               | 0 Disable Exited_L2/L3 ready state interrupt generation                                                |
| 20            | This field is reserved. Reserved                                                                       |
| 21<br>HRDIE   | Hot reset detected interrupt enable. When set and PEX_PME_MES_DR[HRD]=1 generates an interrupt.        |
|               | 1 Enable hot reset state interrupt generation                                                          |
|               | 0 Disable hot reset state interrupt generation                                                         |
| 22<br>LDDIE   | Link down detected interrupt enable. When set and PEX_PME_MES_DR[LDD]=1 generates an interrupt.        |
|               | 1 Enable link down state interrupt generation                                                          |
|               | 0 Disable link down state interrupt generation                                                         |
| 23–24         | This field is reserved. Reserved                                                                       |
| 25<br>AIONIE  | Attention indicator on interrupt enable. When set and PEX_PME_MES_DR[AION]=1 generates an interrupt.   |
|               | 1 Enable attention indicator on message interrupt generation                                           |
|               | Disable attention indicator on message interrupt generation                                            |
| 26<br>AIBIE   | Attention indicator blink interrupt enable. When set and PEX_PME_MES_DR[AIB]=1 generates an interrupt. |
|               | Enable attention indicator blink message interrupt generation                                          |
|               | Disable attention indicator blink message interrupt generation                                         |
| 27<br>AIOFIE  | Attention indicator off interrupt enable. When set and PEX_PME_MES_DR[AIOF]=1 generates an interrupt.  |
|               | Enable attention indicator off message interrupt generation                                            |
|               | Disable attention indicator off message interrupt generation                                           |
| 28            | Power indicator on interrupt enable. When set and PEX_PME_MES_DR[PION]=1 generates an interrupt.       |
| PIONIE        | Enable power indicator on message interrupt generation                                                 |
|               | Disable power indicator on message interrupt generation                                                |
| 29<br>PIBIE   | Power indicator blink interrupt enable. When set and PEX_PME_MES_DR[PIB]=1 generates an interrupt.     |
| 1 1012        | 1 Enable power indicator blink message interrupt generation                                            |
|               | 0 Disable power indicator blink message interrupt generation                                           |
| 30<br>PIOFIE  | Power indicator off interrupt enable. When set and PEX_PME_MES_DR[PIOF]=1 generates an interrupt.      |
|               | 1 Enable power indicator off message interrupt generation                                              |
|               | 0 Disable power indicator off message interrupt generation                                             |
| 31<br>ABPIE   | Attention button pressed interrupt enable. When set and PEX_PME_MES_DR[ABP]=1 generates an interrupt.  |

### PEXx\_PEX\_PME\_MES\_IER field descriptions (continued)

|   | Field |   | Description                                                 |
|---|-------|---|-------------------------------------------------------------|
| I |       | 1 | Enable attention button press message interrupt generation  |
|   |       | 0 | Disable attention button press message interrupt generation |

# 14.6.9 PCI Express power management command register (PEXx\_PEX\_PMCR)

The PCI Express power management command register provides software a mechanism to allow the PCI Express controller to get back to L0 link state.



### PEXx\_PEX\_PMCR field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                               |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–28<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                          |
| 29<br>SPMES | Set PME status. This sets the PME status bit and if PME is enabled (see PCI Express Power Management Status and Control Register (Power_Management_Status_and_Control_Register), for more information) it transmits a PM_PME message upstream. This bit should not be used when in RC mode. This bit is self-clearing.                    |
| 30<br>EXL2S | Exit L2 state. When set exits the link state out of L2/L3 ready state in order to send new requests. The request is only made when entered_L2/L3 ready state is active. This bit is self-clearing. When the link has exited L2/L3 ready state, the status bit Exit_L2/L3 ready state is set. This bit should not be used when in EP mode. |
| 31<br>PTOMR | PME_Turn_Off message request. When set broadcasts a PME turn_off message. This bit should not be used when in EP mode. This bit is self-clearing                                                                                                                                                                                          |

## 14.6.10 IP block revision register 1 (PEXx\_PEX\_IP\_BLK\_REV1)

Address: Base address + BF8h offset



#### PEXx\_PEX\_IP\_BLK\_REV1 field descriptions

| Field          | Description          |
|----------------|----------------------|
| 0–15<br>IP_ID  | Block ID             |
| 16–23<br>IP_MJ | Block Major Revision |
| 24–31<br>IP_MN | Block Minor Revision |

# 14.6.11 IP block revision register 2 (PEXx\_PEX\_IP\_BLK\_REV2)

Address: Base address + BFCh offset



#### PEXx\_PEX\_IP\_BLK\_REV2 field descriptions

| Field           | Description                      |
|-----------------|----------------------------------|
| 0–7<br>-        | This field is reserved. Reserved |
| 8–15<br>IP_INT  | Block integration option         |
| 16–23<br>-      | This field is reserved. Reserved |
| 24–31<br>IP_CFG | Block configuration option       |

# 14.6.12 PCI Express outbound translation address register n (PEXx\_PEXOTARn)

The PCI Express outbound translation address registers select the starting addresses in the system address space for window hits within the PCI Express outbound address translation windows. The new translated address is created by concatenating the transaction offset to this translation address.





#### PEXx\_PEXOTARn field descriptions

| Field       | Description                                                                                                                                                                                                                                               |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–11<br>TEA | Translation extended address. System address which indicates the starting point of the outbound translated address. The translation address must be aligned based on the size field. Corresponds to PCI Express address bits [43:32] (bit 32 is the lsb). |
| 12–31<br>TA | Translation address. System address which indicates the starting point of the outbound translated address. The translation address must be aligned based on the size field. This corresponds to PCI Express address bits [31:12].                         |

# 14.6.13 PCI Express outbound translation extended address register n (PEXx\_PEXOTEARn)

The PCI Express outbound translation extended address registers contain the most-significant bits of a 64 bit translation address.

Address: Base address + C04h offset + (32d  $\times$  i), where i=0d to 4d



#### PEXx PEXOTEARn field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–11  | This field is reserved. |
| -     | Reserved                |

### Chapter 14 PCI Express Interface Controller

## PEXx\_PEXOTEARn field descriptions (continued)

| Field | Description                                                                                                                                                                                                                           |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Translation extended address. System address which indicates the starting point of the outbound translated address. The translation address must be aligned based on the size field. Corresponds to PCI Express address bits [63:44]. |

# 14.6.14 PCI Express outbound window attributes register n (PEXx\_PEXOWAR0)

The PCI Express outbound window attributes registers define the window sizes to translate and other attributes for the translations. 64 Gbytes is the largest window size allowed.



## PEXx\_PEXOWAR0 field descriptions

| Field      | Description                                                                                                                                                                                                                                                                             |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EN    | Enable. This bit enables this address translation window. For the default window, this bit is read-only and always hardwired to 1.                                                                                                                                                      |
|            | <ul> <li>Disable outbound translation window</li> <li>Enable outbound translation window</li> </ul>                                                                                                                                                                                     |
| 1–2        | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 3<br>ROE   | Relaxed ordering enable. When this bit and the RO bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the relaxed ordering bit for the packet is enabled. This bit only applies to memory transactions. |
|            | <ul><li>0 Default ordering</li><li>1 Relaxed ordering</li></ul>                                                                                                                                                                                                                         |
| 4<br>NS    | No snoop enable. When this bit and the NSE bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register) ) is set, the no snoop bit for the packet is enabled. This bit only applies to memory transactions.               |
|            | <ul><li>0 Snoopable</li><li>1 No snoop</li></ul>                                                                                                                                                                                                                                        |
| 5–7<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 8–10<br>TC | Traffic class. This field indicates the traffic class of the outbound packet. This field only applies to memory transaction. All other transaction types should set the TC field to 0.                                                                                                  |
|            | <b>NOTE:</b> Traffic class settings are passed through to the PCI Express link, but no specific actions are taken in the device based on traffic class.                                                                                                                                 |
|            | 000 TC0                                                                                                                                                                                                                                                                                 |
|            | 001 TC1<br>010 TC2                                                                                                                                                                                                                                                                      |
|            | 011 TC3                                                                                                                                                                                                                                                                                 |
|            | 100 TC4                                                                                                                                                                                                                                                                                 |
|            | 101 TC5                                                                                                                                                                                                                                                                                 |
|            | 110 TC6                                                                                                                                                                                                                                                                                 |
| 11         | This field is reserved.                                                                                                                                                                                                                                                                 |
| 11         | Reserved                                                                                                                                                                                                                                                                                |
| 12–15      | Read transaction type. Read transaction type to run on the PCI Express link.                                                                                                                                                                                                            |
| RTT        | Settings not shown are reserved.                                                                                                                                                                                                                                                        |
|            | O010 Configuration read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.                                                                                                                                             |
|            | <ul> <li>Memory read</li> <li>IO read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.</li> </ul>                                                                                                                    |
| 16–19      | Write transaction type. Write transaction type to run on the PCI Express link.                                                                                                                                                                                                          |
| WTT        | Settings not shown are reserved.                                                                                                                                                                                                                                                        |
|            | O010 Configuration write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI                                                                                            |

#### PEXx\_PEXOWAR0 field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | express port must not translate to outbound configuration write transactions on another PCI Express port.                                                                                                                                                                                                               |
|            | 0100 Memory write                                                                                                                                                                                                                                                                                                       |
|            | 0101 Message write. Only support 4-byte size access on a 4-byte address boundary.                                                                                                                                                                                                                                       |
|            | 1000 IO Write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound I/O write transactions on another PCI Express port.                                       |
| 20–25<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                        |
| 26–31      | Outbound window size. Outbound translation window size N which is the encoded 2 (N + 1) -byte window                                                                                                                                                                                                                    |
| OWS        | size. The smallest window size is 4 Kbytes. Note that for the default window (window 0), the outbound window size may be programmed less than the 64-Gbyte maximum. However, accesses that miss all other windows and hit outside the default window is aliased to the default window. Patterns not shown are reserved. |
|            | 001011 4-Kbyte window size                                                                                                                                                                                                                                                                                              |
|            | 001100 8-Kbyte window size                                                                                                                                                                                                                                                                                              |
|            |                                                                                                                                                                                                                                                                                                                         |
|            | 011111 4-Gbyte window size                                                                                                                                                                                                                                                                                              |
|            | 100000 8-Gbyte window size                                                                                                                                                                                                                                                                                              |
|            | 100001 16-Gbyte window size                                                                                                                                                                                                                                                                                             |
|            | 100010 32-Gbyte window size                                                                                                                                                                                                                                                                                             |
|            | 100011 64-Gbyte window size                                                                                                                                                                                                                                                                                             |

# 14.6.15 PCI Express outbound window base address register n (PEXx\_PEXOWBARn)

The PCI Express outbound window base address registers select the base address for the windows which are translated to the external address space. Addresses for outbound transactions are compared to these windows. If such a transaction does not fall within one of these spaces the transaction is forwarded through a default register set.

Address: Base address + C28h offset + (32d  $\times$  i), where i=0d to 3d



#### PEXx\_PEXOWBARn field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–7   | This field is reserved. |
| -     | Reserved                |

## PEXx\_PEXOWBARn field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8–11<br>WBEA | Window base extended address. Source address which is the starting point for the outbound translation window. The window must be aligned based on the size selected in the window size bits. Correspond to internal platform address bits [0:3] . (where 0 is the msb of the internal platform address) |
| 12–31<br>WBA | Window base address. Source address which is the starting point for the outbound translation window. The window must be aligned based on the size selected in the window size bits. This corresponds to internal platform address bits [4:23].                                                          |

# 14.6.16 PCI Express outbound window attributes register n (PEXx\_PEXOWARn)

The PCI Express outbound window attributes registers define the window sizes to translate and other attributes for the translations. 64 Gbytes is the largest window size allowed.





## PEXx\_PEXOWARn field descriptions

| Field | Description                                               |
|-------|-----------------------------------------------------------|
| 0     | Enable. This bit enables this address translation window. |
| EN    |                                                           |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## PEXx\_PEXOWARn field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0 Disable outbound translation window                                                                                                                                                                                                                                                                                |
|              | 1 Enable outbound translation window                                                                                                                                                                                                                                                                                 |
| 1–2          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                     |
| 3<br>ROE     | Relaxed ordering enable. When this bit and the RO bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the relaxed ordering bit for the packet is enabled. This bit only applies to memory transactions.                              |
|              | <ul><li>0 Default ordering</li><li>1 Relaxed ordering</li></ul>                                                                                                                                                                                                                                                      |
| 4<br>NS      | No snoop enable. When this bit and the NSE bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register) ) is set, the no snoop bit for the packet is enabled. This bit only applies to memory transactions.                                            |
|              | 0 Snoopable 1 No snoop                                                                                                                                                                                                                                                                                               |
| 5–7<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                     |
| 8–10<br>TC   | Traffic class. This field indicates the traffic class of the outbound packet. This field only applies to memory transaction. All other transaction types should set the TC field to 0.                                                                                                                               |
|              | <b>NOTE:</b> Traffic class settings are passed through to the PCI Express link, but no specific actions are taken in the device based on traffic class.                                                                                                                                                              |
|              | 000 TC0 001 TC1 010 TC2 011 TC3 100 TC4 101 TC5 110 TC6                                                                                                                                                                                                                                                              |
| 11<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                     |
| 12–15<br>RTT | Read transaction type. Read transaction type to run on the PCI Express link.  Settings not shown are reserved.                                                                                                                                                                                                       |
|              | <ul> <li>Configuration read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.</li> <li>Memory read</li> <li>IO read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.</li> </ul> |
| 16–19        | Write transaction type. Write transaction type to run on the PCI Express link.                                                                                                                                                                                                                                       |
| WTT          | Settings not shown are reserved.                                                                                                                                                                                                                                                                                     |
|              | O010 Configuration write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound configuration write transactions on another PCI Express port.               |

## PEXx\_PEXOWARn field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0100 Memory write                                                                                                                                                                                                                                                                                                                                                                           |
|              | 0101 Message write. Only support 4-byte size access on a 4-byte address boundary.                                                                                                                                                                                                                                                                                                           |
|              | 1000 IO Write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound I/O write transactions on another PCI Express port.                                                                                                           |
| 20–25<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                            |
| 26–31<br>OWS | Outbound window size. Outbound translation window size N which is the encoded 2 (N + 1) -byte window size. The smallest window size is 4 Kbytes. Note that for the default window (window 0), the outbound window size may be programmed less than the 64-Gbyte maximum. However, accesses that miss all other windows and hit outside the default window is aliased to the default window. |
|              | 000000 Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|              | 001010 Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|              | 001011 4-Kbyte window size                                                                                                                                                                                                                                                                                                                                                                  |
|              | 001100 8-Kbyte window size                                                                                                                                                                                                                                                                                                                                                                  |
|              | 011111 4-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                  |
|              | 100000 8-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                  |
|              | 100001 16-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                 |
|              | 100010 32-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                 |
|              | 100011 64-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                 |
|              | 100100 Reserved                                                                                                                                                                                                                                                                                                                                                                             |
|              | 111111 Reserved                                                                                                                                                                                                                                                                                                                                                                             |

# 14.6.17 PCI Express outbound window attributes register 3 (PEXx\_PEXOWAR3)

The PCI Express outbound window attributes registers define the window sizes to translate and other attributes for the translations. 64 Gbytes is the largest window size allowed.



## PEXx\_PEXOWAR3 field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                    |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EN  | Enable. This bit enables this address translation window.                                                                                                                                                                                                                                                                      |
|          | 0 Disable outbound translation window                                                                                                                                                                                                                                                                                          |
|          | 1 Enable outbound translation window                                                                                                                                                                                                                                                                                           |
| 1–2<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                               |
| 3<br>ROE | Relaxed ordering enable. When this bit and the RO bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the relaxed ordering bit for the packet is enabled. This bit only applies to memory transactions.  0 Default ordering 1 Relaxed ordering |

## PEXx\_PEXOWAR3 field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>NS      | No snoop enable. When this bit and the NSE bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the no snoop bit for the packet is enabled. This bit only applies to memory transactions.                                                                                                                               |
|              | 0 Snoopable 1 No snoop                                                                                                                                                                                                                                                                                                                                                                                 |
| 5–7<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 8–10<br>TC   | Traffic class. This field indicates the traffic class of the outbound packet. This field only applies to memory transaction. All other transaction types should set the TC field to 0.                                                                                                                                                                                                                 |
|              | NOTE: Traffic class settings are passed through to the PCI Express link, but no specific actions are taker in the device based on traffic class.                                                                                                                                                                                                                                                       |
|              | 000 TC0                                                                                                                                                                                                                                                                                                                                                                                                |
|              | 001 TC1                                                                                                                                                                                                                                                                                                                                                                                                |
|              | 010 TC2                                                                                                                                                                                                                                                                                                                                                                                                |
|              | 011 TC3                                                                                                                                                                                                                                                                                                                                                                                                |
|              | 100 TC4                                                                                                                                                                                                                                                                                                                                                                                                |
|              | 101 TC5<br>110 TC6                                                                                                                                                                                                                                                                                                                                                                                     |
|              | 111 TC7                                                                                                                                                                                                                                                                                                                                                                                                |
| 11<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 12–15        | Read transaction type. Read transaction type to run on the PCI Express link.                                                                                                                                                                                                                                                                                                                           |
| RTT          | Settings not shown are reserved.                                                                                                                                                                                                                                                                                                                                                                       |
|              | 0010 Configuration read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.                                                                                                                                                                                                                                                            |
|              | <ul> <li>Memory read</li> <li>IO read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.</li> </ul>                                                                                                                                                                                                                                   |
| 16–19        | Write transaction type. Write transaction type to run on the PCI Express link.                                                                                                                                                                                                                                                                                                                         |
| WTT          | Settings not shown are reserved.                                                                                                                                                                                                                                                                                                                                                                       |
|              | O010 Configuration write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound configuration write transactions on another PCI Express port.                                                                                                 |
|              | 0100 Memory write                                                                                                                                                                                                                                                                                                                                                                                      |
|              | 0101 Message write. Only support 4-byte size access on a 4-byte address boundary.                                                                                                                                                                                                                                                                                                                      |
|              | 1000 IO Write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound I/O write transactions on another PCI Express port.                                                                                                                      |
| 20–25<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 26–31<br>OWS | Outbound window size. Outbound translation window size N which is the encoded 2 <sup>(N + 1)</sup> -byte window size. The smallest window size is 4 Kbytes. Note that for the default window (window 0), the outbound window size may be programmed less than the 64-Gbyte maximum. However, accesses that miss all other windows and hit outside the default window is aliased to the default window. |

## PEXx\_PEXOWAR3 field descriptions (continued)

| Field |        | Description          |
|-------|--------|----------------------|
|       | 000000 | Reserved             |
|       | 001010 | Reserved             |
|       | 001011 | 4-Kbyte window size  |
|       | 001100 | 8-Kbyte window size  |
|       | 011111 | 4-Gbyte window size  |
|       | 100000 | 8-Gbyte window size  |
|       | 100001 | 16-Gbyte window size |
|       | 100010 | 32-Gbyte window size |
|       | 100011 | 64-Gbyte window size |
|       | 100100 | Reserved             |
|       | 111111 | Reserved             |

# 14.6.18 PCI Express outbound window attributes register 4 (PEXx\_PEXOWAR4)

The PCI Express outbound window attributes registers define the window sizes to translate and other attributes for the translations. 64 Gbytes is the largest window size allowed.



## PEXx\_PEXOWAR4 field descriptions

| Field        | Description                                                                                                                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | Enable. This bit enables this address translation window.                                                                                                                                                                                                                               |
| EN           | 0 Disable outbound translation window                                                                                                                                                                                                                                                   |
|              | 1 Enable outbound translation window                                                                                                                                                                                                                                                    |
| 1–2          | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 3<br>ROE     | Relaxed ordering enable. When this bit and the RO bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the relaxed ordering bit for the packet is enabled. This bit only applies to memory transactions. |
|              | Default ordering     Relaxed ordering                                                                                                                                                                                                                                                   |
| 4<br>NS      | No snoop enable. When this bit and the NSE bit of the PCI Express device control register (described in PCI Express Device Control Register (Device_Control_Register)) is set, the no snoop bit for the packet is enabled. This bit only applies to memory transactions.                |
|              | 0 Snoopable 1 No snoop                                                                                                                                                                                                                                                                  |
| 5–7          | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 8–10<br>TC   | Traffic class. This field indicates the traffic class of the outbound packet. This field only applies to memory transaction. All other transaction types should set the TC field to 0.                                                                                                  |
|              | NOTE: Traffic class settings are passed through to the PCI Express link, but no specific actions are taken in the device based on traffic class.                                                                                                                                        |
|              | 000 TC0                                                                                                                                                                                                                                                                                 |
|              | 001 TC1<br>010 TC2                                                                                                                                                                                                                                                                      |
|              | 011 TC3                                                                                                                                                                                                                                                                                 |
|              | 100 TC4                                                                                                                                                                                                                                                                                 |
|              | 101 TC5                                                                                                                                                                                                                                                                                 |
|              | 110 TC6<br>111 TC7                                                                                                                                                                                                                                                                      |
| 11           | This field is reserved.                                                                                                                                                                                                                                                                 |
| -            | Reserved                                                                                                                                                                                                                                                                                |
| 12–15<br>RTT | Read transaction type. Read transaction type to run on the PCI Express link.                                                                                                                                                                                                            |
|              | Settings not shown are reserved.                                                                                                                                                                                                                                                        |
|              | O010 Configuration read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.                                                                                                                                             |
|              | 0100 Memory read                                                                                                                                                                                                                                                                        |
|              | 1000 IO read. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary.                                                                                                                                                        |
| 16–19        | Write transaction type. Write transaction type to run on the PCI Express link.                                                                                                                                                                                                          |
| WTT          | Settings not shown are reserved.                                                                                                                                                                                                                                                        |
|              | O010 Configuration write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI                                                                                            |

### PEXx\_PEXOWAR4 field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | express port must not translate to outbound configuration write transactions on another PCI Express port.  0100 Memory write                                                                                                                                                                                                                                                                           |
|              | 0101 Message write. Only support 4-byte size access on a 4-byte address boundary.                                                                                                                                                                                                                                                                                                                      |
|              | 1000 IO Write. Supported only when in RC mode and size of less than or equal to 4 bytes and not crossing 4-byte address boundary. Note that inbound write transactions on one PCI express port must not translate to outbound I/O write transactions on another PCI Express port.                                                                                                                      |
| 20–25<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 26–31<br>OWS | Outbound window size. Outbound translation window size N which is the encoded 2 <sup>(N + 1)</sup> -byte window size. The smallest window size is 4 Kbytes. Note that for the default window (window 0), the outbound window size may be programmed less than the 64-Gbyte maximum. However, accesses that miss all other windows and hit outside the default window is aliased to the default window. |
|              | 000000 Reserved                                                                                                                                                                                                                                                                                                                                                                                        |
|              | 001010 Reserved                                                                                                                                                                                                                                                                                                                                                                                        |
|              | 001011 4-Kbyte window size                                                                                                                                                                                                                                                                                                                                                                             |
|              | 001100 8-Kbyte window size                                                                                                                                                                                                                                                                                                                                                                             |
|              | 011111 4-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                             |
|              | 100000 8-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                             |
|              | 100001 16-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                            |
|              | 100010 32-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                            |
|              | 100011 64-Gbyte window size                                                                                                                                                                                                                                                                                                                                                                            |
|              | 100100 Reserved                                                                                                                                                                                                                                                                                                                                                                                        |
|              | 111111 Reserved                                                                                                                                                                                                                                                                                                                                                                                        |

# 14.6.19 PCI Express inbound translation address register n (PEXx\_PEXITARn)

The PCI Express inbound translation address registers contain the translated internal platform address to be used. Note that PEXITAR0 does not exist in the memory-mapped space; it is a fixed translation to the internal configuration (CCSR) space.

Address: Base address + DA0h offset + (32d × i), where i=0d to 2d



### PEXx\_PEXITARn field descriptions

| Field | Description             |
|-------|-------------------------|
| 0–7   | This field is reserved. |
| -     | Reserved                |

### PEXx\_PEXITARn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                      |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8–11<br>TEA | Translation extended address. Target address which indicates the starting point of the inbound translated address. The translation address must be aligned based on the size field. Corresponds to internal platform address bits [0:3] where bit 0 is the msb of the internal platform address. |
| 12–31<br>TA | Translation address. Target address which indicates the starting point of the inbound translated address. The translation address must be aligned based on the size field. This corresponds to internal platform address bits [4:23].                                                            |

# 14.6.20 PCI Express inbound window base address register n (PEXx\_PEXIWBARn)

The PCI Express inbound window base address registers select the base address for the windows which are translated to an alternate target address space. In root complex (RC) mode, addresses for inbound transactions are compared to these windows. In RC mode, the BAR for inbound window 0 is located in the PCI Express type 1 configuration header space and the BARs for inbound windows 1-3 (PEXIWBAR[1-3]) are implemented as described in this section. In endpoint (EP) mode, these registers are not implemented in the memory-mapped space. Reading these registers in EP mode returns all zeros and writing to these offsets has no consequences. All base address registers in EP are located in the PCI Express type 0 configuration header space. Note that PEXIWBAR1 only supports 32-bit PCI Express address space.

Address: Base address + DA8h offset + (32d × i), where i=0d to 2d



### PEXx\_PEXIWBARn field descriptions

| Field        | Description                                                                                                                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–11<br>WBEA | Window base extended address. This field corresponds to PCI Express address bits [43:32]. Note that the extended address is supported for windows 2 and 3 only; for PEXIWBAR1, these bits are reserved and must be 0.                    |
| 12–31<br>WBA | Window base address. Source address which is the starting point for the inbound translation window. The window must be aligned based on the size selected in the window size bits. This corresponds to PCI Express address bits [31:12]. |

# 14.6.21 PCI Express inbound window base extended address register n (PEXx\_PEXIWBEARn)

The PCI Express inbound window base extended address registers contain the most-significant bits of a 64 bit base address.





### PEXx\_PEXIWBEARn field descriptions

| Field         | Description                                                                              |
|---------------|------------------------------------------------------------------------------------------|
| _             | This field is reserved. Reserved                                                         |
| 12–31<br>WBEA | Window base extended address. This field corresponds to PCI Express address bits [63:44] |

# 14.6.22 PCI Express inbound window attributes register n (PEXx\_PEXIWARn)

The PCI Express inbound window attributes registers define the window sizes to translate and other attributes for the translations. 64 Gbytes is the largest window size allowed.



PEXx\_PEXIWARn field descriptions

| Field   | Description                                                                                                                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>EN | Enable. This bit controls the enabling/disabling of the translation window.                                                                                                                                               |
|         | 0 Disable inbound window translation                                                                                                                                                                                      |
|         | 1 Enable inbound window translation                                                                                                                                                                                       |
| 1       | This field is reserved.                                                                                                                                                                                                   |
| -       | Reserved                                                                                                                                                                                                                  |
| 2<br>PF | Prefetchable. This bit indicates that the address space is prefetchable. This bit corresponds to the prefetchable bit in the BAR in the PCI Express type 0 header. This bit drives the BAR's prefetchable bit in EP mode. |
|         | 0 Not prefetchable                                                                                                                                                                                                        |
|         | 1 Prefetchable                                                                                                                                                                                                            |
| 3–7     | This field is reserved. Reserved                                                                                                                                                                                          |

## PEXx\_PEXIWARn field descriptions (continued)

| Field        | Description                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8–11<br>TRGT | Target interface. If this field is set to anything other than local memory space, the attributes for the transaction must be assigned in a corresponding outbound window at the target. |
|              | 0000 Reserved                                                                                                                                                                           |
|              | 0001 PCI Express 2-PCI Express controller 2 should not use this encoding                                                                                                                |
|              | O010 PCI Express 1-PCI Express controller 1 should not use this encoding                                                                                                                |
|              | 0011-1110 Reserved                                                                                                                                                                      |
| 12–15        | 1111 Local memory space  Read transaction type. Read transaction type to send to target interface.                                                                                      |
| RTT          |                                                                                                                                                                                         |
|              | If the transaction is not going to local memory space                                                                                                                                   |
|              | 0000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | 0100 Read                                                                                                                                                                               |
|              | 0101 Reserved                                                                                                                                                                           |
|              | 0110 Reserved                                                                                                                                                                           |
|              | 0111 Reserved                                                                                                                                                                           |
|              | 1000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | 1111 Reserved                                                                                                                                                                           |
|              | If the transaction is going to local memory space                                                                                                                                       |
|              | 0000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | 0100 Read, do not snoop local processor                                                                                                                                                 |
|              | 0101 Read, snoop local processor                                                                                                                                                        |
|              | 0110 Reserved                                                                                                                                                                           |
|              | 0111 Read, snoop local processor, unlock L2 cache line                                                                                                                                  |
|              | 1000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | 1111 Reserved                                                                                                                                                                           |
| 16–19        | Write transaction type. Write transaction type to send to target interface.                                                                                                             |
| WTT          | If the transaction is not going to local memory space                                                                                                                                   |
|              | 0000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | <br>0100 Write                                                                                                                                                                          |
|              | 0101 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |
|              | 0110 Reserved                                                                                                                                                                           |
|              | 0111 Reserved                                                                                                                                                                           |
|              | 1000 Reserved                                                                                                                                                                           |
|              |                                                                                                                                                                                         |

## PEXx\_PEXIWARn field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 1111 Reserved                                                                                                                                                                                                              |
|              | If the transaction is going to local memory space                                                                                                                                                                          |
|              | 0000 Reserved                                                                                                                                                                                                              |
|              |                                                                                                                                                                                                                            |
|              | 0100 Write, do not snoop local processor                                                                                                                                                                                   |
|              | 0101 Write, snoop local processor                                                                                                                                                                                          |
|              | 0110 Write, snoop local processor, allocate L2 cache line                                                                                                                                                                  |
|              | 0111 Write, snoop local processor, allocate and lock L2 cache line                                                                                                                                                         |
|              | 1000 Reserved                                                                                                                                                                                                              |
|              |                                                                                                                                                                                                                            |
|              | 1111 Reserved                                                                                                                                                                                                              |
| 20–25        | This field is reserved.                                                                                                                                                                                                    |
| -            | Reserved                                                                                                                                                                                                                   |
| 26–31<br>IWS | Inbound window size. Inbound translation window size N which is the encoded 2 <sup>(N + 1)</sup> -bytes window size. The smallest window size is 4 Kbytes. For EP mode, this field directly controls the size of the BARs. |
|              | 000000 Reserved                                                                                                                                                                                                            |
|              | <br>001010 Reserved                                                                                                                                                                                                        |
|              | 001011 4-Kbyte window size                                                                                                                                                                                                 |
|              | 001100 8-Kbyte window size                                                                                                                                                                                                 |
|              |                                                                                                                                                                                                                            |
|              | 011111 4-Gbyte window size                                                                                                                                                                                                 |
|              | 100000 8-Gbyte window size                                                                                                                                                                                                 |
|              | 100001 16-Gbyte window size                                                                                                                                                                                                |
|              | 100010 32-Gbyte window size                                                                                                                                                                                                |
|              | 100011 64-Gbyte window size                                                                                                                                                                                                |
|              | 100100 Reserved                                                                                                                                                                                                            |
|              |                                                                                                                                                                                                                            |
|              | 111111 Reserved                                                                                                                                                                                                            |

# 14.6.23 PCI Express error detect register (PEXx\_PEX\_ERR\_DR)

The PCI Express error detect register contains error status bits that are detected by hardware. The detected error bits are write-1-to-clear type registers. Reading from these registers occurs normally; however, write operations can clear but not set bits. A bit is cleared whenever the register is written, and the data in the corresponding bit location is a 1. For example, to clear bit 6 and not affect any other bits in the register, the value 0b0200\_0000 is written to the register. When an error is detected the appropriate error bit is set. Subsequent errors sets the appropriate error bits in the error detection registers, but only the first error for a particular unit have any relevant information captured. The interrupt enable bits are used to allow or block the error reporting to the interrupt mechanism while the disable bits are used to prevent or allow the setting of the status bits.





## PEXx\_PEX\_ERR\_DR field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ME    | Multiple errors. Detecting multiple errors of the same type. An error is considered as multiple error when its detect bit is set and the same error is occurring again. Note that this bit does not track the ordering of when the error occurs.                                                                                                                                                                                                                                                                                                                      |
|            | 1 Multiple errors were detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | 0 Multiple errors were not detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1–7        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8<br>PCT   | PCI Express completion time-out. A completion time-out condition was detected for a non-posted, outbound PCI Express transaction. An error response is sent back to the requestor. Note that a completion timeout counter only starts when the non-posted request was able to send to the link partner.  1 A completion time-out on the PCI Express link was detected. Note that a completion timeout error is a fatal error. If a completion timeout error is detected, the system has become unstable. Hot reset is recommended to restore stability of the system. |
|            | 0 No completion time-out on the PCI Express link detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9 -        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10<br>PCAC | PCI Express completer abort (CA) completion. A completion with CA status was received.  1 A completion with CA status was detected.  0 No completion with CA status detected.                                                                                                                                                                                                                                                                                                                                                                                         |
| 11<br>PNM  | PCI Express no map. An inbound transaction that is not mapped to any inbound windows was detected. In RC mode, a posted transaction will be dropped silently and this bit will be set. A nonposted transaction will return a completion without data (Cpl) packet with a UR completion status to the requester and this bit is set. For EP mode, a Cpl packet with a UR completion status is sent back to the requester but does not set this bit.                                                                                                                    |

## PEXx\_PEX\_ERR\_DR field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 1 A no-map transaction was detected in RC mode.                                                                                                                                                                                                                        |
|             | 0 No no-map transaction detected.                                                                                                                                                                                                                                      |
| 12<br>CDNSC | Completion with data not successful. A completion with data packet was received with a non successful status (that is, UR, CA or CRS status).                                                                                                                          |
|             | 1 Completion with data non successful packet was detected.                                                                                                                                                                                                             |
|             | 0 No completion with data non successful packet detected.                                                                                                                                                                                                              |
| 13<br>CRSNC | CRS non configuration. A completion was detected for a non configuration cycle and with CRS status. See PCI Express configuration space access for more information.                                                                                                   |
|             | 1 CRS non configuration packet was detected.                                                                                                                                                                                                                           |
|             | 0 No CRS non configuration packet detected.                                                                                                                                                                                                                            |
| 14<br>ICCA  | Invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA configuration access. Access to an illegal configuration space from PEX_CONFIG_ADDR/PEX_CONFIG_DATA was detected.                                                                                                              |
|             | 1 Invalid CONFIG_ADDR/PEX_CONFIG_DATA access detected                                                                                                                                                                                                                  |
|             | 0 No invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA access detected                                                                                                                                                                                                           |
| 15<br>IACA  | Invalid ATMU configuration access. Access to an illegal configuration space from an ATMU window was detected.                                                                                                                                                          |
|             | <ul><li>1 Invalid ATMU configuration access was detected</li><li>0 No invalid ATMU configuration access detected</li></ul>                                                                                                                                             |
| 16<br>CRST  | CRS thresholded. An outbound configuration transaction was retried and thresholded due to a CRS completion status. An error response is sent back to the requestor. See PCI Express configuration retry timeout register (PEX_PEX_CONF_RTY_TOR), for more information. |
|             | A CRS threshold condition was detected for an outbound configuration transaction     No CRS threshold condition detected                                                                                                                                               |
| 17<br>MIS   | Message invalid size. An outbound message transaction that is greater than 4 bytes or crosses a 4-byte boundary was detected. See Outbound ATMU message generation, for more information.                                                                              |
|             | <ul><li>1 An invalid size outbound message transaction was detected</li><li>0 No invalid size outbound message transaction detected</li></ul>                                                                                                                          |
| 18<br>IOIS  | I/O invalid size. An outbound I/O transaction that is greater than 4 bytes or crosses a 4-byte boundary was detected.                                                                                                                                                  |
|             | 1 An invalid size outbound I/O transaction was detected                                                                                                                                                                                                                |
|             | 0 No invalid size outbound I/O transaction detected                                                                                                                                                                                                                    |
| 19<br>CIS   | Configuration invalid size. An outbound configuration transaction that is greater than 4 bytes or crosses a 4-byte boundary was detected.                                                                                                                              |
|             | 1 An invalid size outbound configuration transaction was detected                                                                                                                                                                                                      |
|             | 0 No invalid size outbound configuration transaction detected                                                                                                                                                                                                          |
| 20<br>CIEP  | Configuration invalid EP. An outbound ATMU configuration transaction request was seen when in EP mode.                                                                                                                                                                 |
|             | <ul> <li>An outbound configuration transaction while in EP was detected</li> <li>No outbound configuration transaction in EP detected</li> </ul>                                                                                                                       |
| 21<br>IOIEP | I/O invalid EP. An outbound I/O transaction request was seen when in EP mode.                                                                                                                                                                                          |

## PEXx\_PEX\_ERR\_DR field descriptions (continued)

| Description                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------|
| 1 An outbound I/O transaction while in EP was detected                                                            |
| 0 No outbound I/O transaction in EP detected                                                                      |
| Outbound ATMU crossing. An outbound crossing ATMU transaction was detected.                                       |
| 1 An outbound transaction that hits in one window and crosses overing it was detected                             |
| 0 No outbound ATMU crossing condition detected                                                                    |
| I/O invalid address. An outbound I/O transaction with a translated address of greater than 4 Gbytes was detected. |
| 1 A greater than 4-Gbyte I/O address was detected                                                                 |
| 0 No greater than 4-Gbyte I/O address detected                                                                    |
| This field is reserved. Reserved                                                                                  |
|                                                                                                                   |

# 14.6.24 PCI Express error interrupt enable register (PEXx\_PEX\_ERR\_EN)

The PCI Express error interrupt enable register allows interrupts to be generated when the corresponding PCI Express error detect register bits are set.



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## PEXx\_PEX\_ERR\_EN field descriptions

| Field         | Description                                                                                                                            |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 0–7           | This field is reserved. Reserved                                                                                                       |
| 8<br>PCTIE    | PCI Express completion time-out interrupt enable. When set and PEX_ERR_DR[PCT]=1 generates an interrupt.                               |
|               | 1 Enable PCI Express completion time-out interrupt generation                                                                          |
|               | 0 Disable PCI Express completion time-out interrupt generation                                                                         |
| 9 -           | This field is reserved. Reserved                                                                                                       |
| 10<br>PCACIE  | PCI Express CA completion interrupt enable. When set and PEX_ERR_DR[PCAC]=1 generates an interrupt.                                    |
|               | 1 Enable completion with CA status interrupt generation                                                                                |
|               | 0 Disable completion with CA status interrupt generation                                                                               |
| 11            | PCI Express no map interrupt enable. When set and PEX_ERR_DR[PNM]=1 generates an interrupt.                                            |
| PNMIE         | 1 Enable no map PCI Express packet interrupt generation                                                                                |
|               | 0 Disable no map PCI Express packet interrupt generation                                                                               |
| 12<br>CDNSCIE | Completion with data not successful interrupt enable. When this bit is set and PEX_ERR_DR[CDNSC] = 1 generates an interrupt.           |
|               | 1 Enable completion with data non successful interrupt generation                                                                      |
|               | 0 Disable completion with data non successful interrupt generation                                                                     |
| 13<br>CRSNCIE | CRS non configuration interrupt enable. When this bit is set and PEX_ERR_DR[CRSNC] = 1 generates an interrupt.                         |
|               | 1 Enable CRS non configuration interrupt generation                                                                                    |
|               | 0 Disable CRS non configuration interrupt generation                                                                                   |
| 14<br>ICCAIE  | Invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA configuration access interrupt enable. When set and PEX_ERR_DR[ICCA]=1 generates an interrupt. |
|               | 1 Enable invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA access interrupt generation                                                           |
|               | 0 Disable invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA access interrupt generation.                                                         |
| 15            | Invalid ATMU configuration access. When set and PEX_ERR_DR[IACA]=1 generates an interrupt.                                             |
| IACAIE        | 1 Enable invalid ATMU configuration access interrupt generation                                                                        |
|               | 0 Disable invalid ATMU configuration access interrupt generation                                                                       |
| 16            | CRS thresholded interrupt enable. When set and PEX_ERR_DR[CRST]=1 generates an interrupt.                                              |
| CRSTIE        | 1 Enable CRS threshold interrupt generation                                                                                            |
|               | 0 Disable CRS threshold interrupt generation                                                                                           |
| 17<br>MISIE   | Message invalid size interrupt enable. When set and PEX_ERR_DR[MIS]=1 generates an interrupt.                                          |
|               | 1 Enable invalid outbound message size interrupt generation                                                                            |
|               | 0 Disable invalid outbound message size interrupt generation                                                                           |
| 18            | I/O invalid size interrupt enable. When set and PEX_ERR_DR[IOIS]=1 generates an interrupt.                                             |
| IOISIE        | 1 Enable invalid outbound I/O size interrupt generation                                                                                |
|               | 0 Disable invalid outbound I/O size interrupt generation                                                                               |

# PEXx\_PEX\_ERR\_EN field descriptions (continued)

| Field       | Description                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------|
| 19<br>CISIE | Configuration invalid size interrupt enable. When set and PEX_ERR_DR[CIS]=1 generates an interrupt. |
|             | 1 Enable invalid outbound configuration size interrupt generation                                   |
|             | 0 Disable invalid outbound configuration size interrupt generation                                  |
| 20          | Configuration invalid EP interrupt enable. When set and PEX_ERR_DR[CIEP]=1 generates an interrupt.  |
| CIEPIE      | 1 Enable outbound configuration transaction while in EP mode interrupt generation                   |
|             | 0 Disable outbound configuration transaction in EP mode interrupt generation                        |
| 21          | I/O invalid EP interrupt enable. When set and PEX_ERR_DR[IOIEP]=1 generates an interrupt.           |
| IOIEPIE     | 1 Enable outbound I/O transaction EP mode interrupt generation                                      |
|             | 0 Disable outbound I/O transaction EP mode interrupt generation                                     |
| 22          | Outbound ATMU crossing interrupt enable. When set and PEX_ERR_DR[OAC]=1 generates an interrupt.     |
| OACIE       | 1 Enable outbound crossing ATMU interrupt generation                                                |
|             | 0 Disable outbound crossing ATMU interrupt generation                                               |
| 23          | I/O address invalid enable. When set and PEX_ERR_DR[IOIA]=1 generates an interrupt.                 |
| IOIAIE      | 1 Enable greater than 4G I/O address interrupt generation                                           |
|             | 0 Disable greater than 4G I/O address interrupt generation                                          |
| 24–31<br>-  | This field is reserved. Reserved                                                                    |

# 14.6.25 PCI Express error disable register (PEXx\_PEX\_ERR\_DISR)

The PCI Express error disable register controls the setting of the PCI Express error detect register's bits.



PEXx\_PEX\_ERR\_DISR field descriptions

| Field | Description                                                                                    |
|-------|------------------------------------------------------------------------------------------------|
| 0     | Multiple errors disable. When set disables the setting of PEX_ERR_DR[ME] bit.                  |
| MED   | 1 Disable multiple errors detection                                                            |
|       | 0 Enable multiple errors detection                                                             |
| 1–7   | This field is reserved. Reserved                                                               |
| 8     | PCI Express completion time-out disable. When set disables the setting of PEX_ERR_DR[PCT] bit. |
| PCTD  | 1 Disable PCI Express completion time-out detection                                            |
|       | 0 Enable PCI Express completion time-out detection                                             |
| 9 -   | This field is reserved. Reserved                                                               |

## PEXx\_PEX\_ERR\_DISR field descriptions (continued)

| Field        | Description                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| 10<br>PCACD  | PCI Express CA completion disable. When set disables the setting of PEX_ERR_DR[PCAC] bit.                                    |
|              | 1 Disable completion with CA status detection                                                                                |
|              | 0 Enable completion with CA status detection                                                                                 |
| 11           | PCI Express no map disable. When set disables the setting of PEX_ERR_DR[PNM] bit.                                            |
| PNMD         | 1 Disable no map PCI Express packet detection                                                                                |
|              | 0 Enable no map PCI Express packet detection                                                                                 |
| 12<br>CDNSCD | Completion with data not successful disable. When set disables the setting of PEX_ERR_DR[CDNSC] bit.                         |
| CDNSCD       | Disable completion with data not successful detection                                                                        |
|              | 0 Enable completion with data not successful detection                                                                       |
| 13           | CRS non configuration disable. When set disables the setting of PEX_ERR_DR[CRSNC] bit.                                       |
| CRSNCD       | 1 Disable CRS non configuration detection                                                                                    |
|              | 0 Enable CRS non configuration detection                                                                                     |
| 14<br>ICCAD  | Invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA configuration access disable. When set disables the setting of PEX_ERR_DR[ICCA] bit. |
|              | 1 Disable invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA access detection                                                           |
|              | 0 Enable invalid PEX_CONFIG_ADDR/PEX_CONFIG_DATA access detection                                                            |
| 15           | Invalid ATMU configuration access. When set disables the setting of PEX_ERR_DR[IACA] bit.                                    |
| IACAD        | 1 Disable invalid ATMU configuration access detection                                                                        |
|              | 0 Enable invalid ATMU configuration access detection                                                                         |
| 16           | CRS thresholded disable. When set disables the setting of PEX_ERR_DR[CRST] bit.                                              |
| CRSTD        | 1 Disable CRS threshold detection                                                                                            |
|              | 0 Enable CRS threshold detection                                                                                             |
| 17<br>MISD   | Message invalid size disable. When set disables the setting of PEX_ERR_DR[MIS] bit.                                          |
| MISD         | 1 Disable invalid outbound message size detection                                                                            |
|              | 0 Enable invalid outbound message size detection                                                                             |
| 18           | I/O invalid size disable. When set disables the setting of PEX_ERR_DR[IOIS] bit.                                             |
| IOISD        | 1 Disable invalid outbound I/O size detection                                                                                |
|              | 0 Enable invalid outbound I/O size detection                                                                                 |
| 19           | Configuration invalid size disable. When set disables the setting of PEX_ERR_DR[CIS] bit.                                    |
| CISD         | 1 Disable invalid outbound configuration size detection                                                                      |
|              | 0 Enable invalid outbound configuration size detection                                                                       |
| 20           | Configuration invalid EP disable. When set disables the setting of PEX_ERR_DR[CIEP] bit.                                     |
| CIEPD        | 1 Disable outbound configuration transaction EP mode detection                                                               |
|              | 0 Enable outbound configuration transaction EP mode detection                                                                |
| 21           | I/O invalid EP disable. When set disables the setting of PEX_ERR_DR[IOEP] bit.                                               |
| IOIEPD       | 1 Disable outbound I/O transaction EP mode detection                                                                         |
|              | 0 Enable outbound I/O transaction EP mode detection                                                                          |

#### PCI Express memory-mapped registers

## PEXx\_PEX\_ERR\_DISR field descriptions (continued)

| Field      | Description                                                                           |
|------------|---------------------------------------------------------------------------------------|
| 22<br>OACD | Outbound ATMU crossing disable. When set disables the setting of PEX_ERR_DR[OAC] bit. |
|            | 1 Disable outbound crossing ATMU detection                                            |
|            | 0 Enable outbound crossing ATMU detection                                             |
| 23         | I/O invalid address disable. When set disables the setting of PEX_ERR_DR[IOIA] bit.   |
| IOIAD      | 1 Disable greater than 4G I/O address detection                                       |
|            | 0 Enable greater than 4G I/O address detection                                        |
| 24–31<br>- | This field is reserved. Reserved                                                      |

# 14.6.26 PCI Express error capture status register (PEXx\_PEX\_ERR\_CAP\_STAT)

The PCI Express error capture status register allows vital error information to be captured when an error occurs. Note that no further error capturing is performed until the ECV bit is cleared.





## PEXx\_PEX\_ERR\_CAP\_STAT field descriptions

| Field         | Description                                                                                                                                                                                       |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–24<br>-     | This field is reserved. Reserved                                                                                                                                                                  |  |  |
| 25<br>TO      | Transaction originator. This field Indicates whether the originator of the transaction is from PEX_CONFIG_ADDR/PEX_CONFIG_DATA.                                                                   |  |  |
|               | 1 Transaction originated from PEX_CONFIG_ADDR/PEX_CONFIG_DATA.                                                                                                                                    |  |  |
|               | 0 Transaction not originated from PEX_CONFIG_ADDR/PEX_CONFIG_DATA.                                                                                                                                |  |  |
| 26–30<br>GSID | Global source ID. This field indicates the internal platform global source ID that the error transaction originates. This field only applies to non PEX_CONFIG_ADDR/PEX_CONFIG_DATA transactions. |  |  |

#### PEXx\_PEX\_ERR\_CAP\_STAT field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                       |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|           | All settings not shown are reserved.                                                                                                                                                                                                                              |  |
|           | 00001 PCI Express 2                                                                                                                                                                                                                                               |  |
|           | 00010 PCI Express 1                                                                                                                                                                                                                                               |  |
|           | 00101 USB                                                                                                                                                                                                                                                         |  |
|           | 00111 Security                                                                                                                                                                                                                                                    |  |
|           | 01010 Boot sequencer                                                                                                                                                                                                                                              |  |
|           | 01011 eSDHC                                                                                                                                                                                                                                                       |  |
|           | 10000 Processor 0 instruction                                                                                                                                                                                                                                     |  |
|           | 10001 Processor 0 data                                                                                                                                                                                                                                            |  |
|           | 10010 Processor 1 instruction                                                                                                                                                                                                                                     |  |
|           | 10011 Processor 1 data                                                                                                                                                                                                                                            |  |
|           | 10100 QUICC Engine                                                                                                                                                                                                                                                |  |
|           | 10101 DMA                                                                                                                                                                                                                                                         |  |
|           | 10111 SAP (system access port)                                                                                                                                                                                                                                    |  |
|           | 11000 eTSEC1                                                                                                                                                                                                                                                      |  |
|           | 11001 eTSEC2                                                                                                                                                                                                                                                      |  |
|           | 11010 eTSEC3                                                                                                                                                                                                                                                      |  |
| 31<br>ECV | Error capture valid. This bit indicates that the capture registers 0-3 contain valid info. This bit when set indicates that the captured registers contain valid capturing information. No new capturing is done unless this bit is cleared by writing a 1 to it. |  |

# 14.6.27 PCI Express error capture register n (PEXx\_PEX\_ERR\_CAP\_Rn)

PEX\_ERR\_CAP\_Rn allow vital error information to be captured when an error occurs. Different error information is reported depending on whether the error source is from an outbound transaction from an internal source or from an inbound transaction from an external source; the source of the captured error is reflected in PEX\_ERR\_CAP\_STAT[GSID]. Note that after the initial error is captured, no further capturing is performed until the PEX\_ERR\_CAP\_STAT[ECV] bit is clear.

See Error capture registers for further details.

Address: Base address + E28h offset +  $(4d \times i)$ , where i=0d to 3d



#### PEXx\_PEX\_ERR\_CAP\_Rn field descriptions

| Field        | Description   |
|--------------|---------------|
| 0–31<br>DATA | Captured Data |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### PEXx\_PEX\_ERR\_CAP\_Rn field descriptions (continued)

| Field | Description |
|-------|-------------|
|-------|-------------|

# 14.7 PCI Express configuration-space registers

This table lists the PCI Express configuration-space registers.

Table 14-177. PCI Express configuration-space registers

| Address offset (Hex) |                                                                                |
|----------------------|--------------------------------------------------------------------------------|
| 000-03F              | PCI Compatible configuration header                                            |
|                      | (See PCI compatible configuration headers for more information.)               |
| 040-0FF              | PCI-compatible device-specific configuration space                             |
|                      | (See PCI compatible device-specific configuration space for more information.) |
| 100-134              | PCI Express Extended Configuration Registers                                   |
|                      | (See PCI Express extended configuration space for more information.)           |
| 138-3FF              | Reserved                                                                       |
| 400-6FF              | PCI Express Controller Internal CSRs <sup>1</sup>                              |
|                      | (See PCI Express controller internal CSRs for more information.)               |
| 700-FFF              | Reserved                                                                       |

<sup>1.</sup> Note that the PCI Express Controller Internal CSRs are not accessible by inbound PCI Express configuration transactions. Attempts to access these registers returns all 0s.

## 14.7.1 PCI compatible configuration headers

The first 64 bytes of the 256-byte, PCI-compatible configuration space consists of a predefined header that every PCI device must support.

Many registers in the predefined header are defined the same for all PCI Express devices.

These registers are shown in this figure.

| Devi | ce ID       | Vend             | lor ID              |
|------|-------------|------------------|---------------------|
| Sta  | tus         | Com              | nmand               |
|      | Class Code  |                  | Revision ID         |
| BIST | Header Type | Latency Timer    | Cache Line Size     |
|      |             |                  |                     |
|      |             |                  |                     |
|      |             |                  |                     |
|      |             |                  |                     |
|      |             |                  |                     |
|      |             |                  |                     |
|      | Header Type | e (0/1) Specific |                     |
|      | Header Type | e (0/1) Specific |                     |
|      | Header Type | e (0/1) Specific |                     |
|      | Header Typ  | e (0/1) Specific | Capabilities Pointe |

Figure 14-176. PCI Express PCI-compatible configuration header common registers

The remaining registers in the header may have differing layouts depending on the function of the device. There are two header types applicable to PCI Express. Type 0 headers are typically used by endpoints; Type 1 headers are used by root complexes and switches/bridges.

# 14.8 Type 0 configuration header registers

The figure below shows the type 0 header.

### **NOTE**

The BIST register (0x0F) is optional and reserved on the PCI Express controller.

| Reserved  |               |                | Ad<br>Offset         | dress<br>: <b>(Hex</b> ) |
|-----------|---------------|----------------|----------------------|--------------------------|
| Device ID |               | Vendor ID      |                      | 00                       |
| Status    |               | Command        |                      | 04                       |
|           | Class Code    |                | Revision ID          | 08                       |
| BIST      | Header Type   | Latency Timer  | Cache Line Size      | 0C                       |
|           |               |                |                      | 10                       |
|           |               |                |                      | 14                       |
|           |               |                |                      | 18                       |
|           | Base Addr     | ess Registers  |                      | 1C                       |
|           |               |                |                      | 20                       |
|           |               |                |                      | 24                       |
|           |               |                |                      | 28                       |
| Subsy     | stem ID       | Subsyste       | em Vendor            | 2C                       |
|           | Expansion ROM | M Base Address |                      | 30                       |
|           |               |                | Capabilities Pointer | 34                       |
|           |               |                |                      | 38                       |
| MAX_LAT   | MIN_GNT       | Interrupt Pin  | Interrupt Line       | 3C                       |

Figure 14-177. PCI Express PCI-Compatible Configuration Header—Type 0

# 14.8.1 PCI Express Vendor ID Register (Vendor\_ID\_Register)

The vendor ID register is used to identify the manufacturer of the device.



Vendor\_ID\_Register field descriptions

| Field             | Description        |
|-------------------|--------------------|
| 15–0<br>Vendor_ID | 0x1957 (Freescale) |

# 14.8.2 PCI Express Device ID Register (Device\_ID\_Register)

The device ID register is used to identify the device.

### **NOTE**

See bitfield description table for reset value.



Device\_ID\_Register field descriptions

| Field     |        | Description |
|-----------|--------|-------------|
| 15–0      | 0x0102 | P1021E      |
| Device_ID | 0x0103 | P1021       |
|           | 0x010a | P1012E      |
|           | 0x010b | P1012       |

# 14.8.3 PCI Express Command Register (Command\_Register)

The command register provides control over the ability to generate and respond to PCI Express cycles.



### Command\_Register field descriptions

| Field                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15–11<br>-               | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 10<br>Interrupt_Disable  | Controls the ability to generate INTx interrupt messages.  Any INTx emulation interrupts already asserted by this device must be deasserted when this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                          | Enables INTx interrupt messages     Disables INTx interrupt messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 9 -                      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 8<br>SERR                | Controls the reporting of fatal and non-fatal errors detected by the device to the root complex.  NOTE: The error control and status bits in the command and status registers control PCI-compatible error reporting. PCI Express advanced error reporting is controlled by the PCI Express device control register described in PCI Express Device Control Register (Device_Control_Register), and the advance error reporting capability structure described in sections PCI Express Advanced Error Reporting Capability ID Register (Advanced_Error_Reporting_Capability_ID_Register) through PCI Express Error Source ID Register (Error_Source_ID_Register).  O Disables reporting  Enables reporting |  |
| 7 -                      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 6 Parity_error_ response | Controls whether this PCI Express controller responds to parity errors.  NOTE: The error control and status bits in the command and status registers control PCI-compatible error reporting. PCI Express advanced error reporting is controlled by the PCI Express device control register described in PCI Express Device Control Register (Device_Control_Register), and the advance error reporting capability structure described in sections PCI Express Advanced                                                                                                                                                                                                                                     |  |

## Command\_Register field descriptions (continued)

| Field        | '                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|              | Error Reporting Capability ID Register (Advanced_Error_Reporting_Capability_ID_Register) through PCI Express Error Source ID Register (Error_Source_ID_Register) .                                                                                                                                                                                                              |  |  |  |
|              | 0 Parity errors are ignored and normal operation continues.                                                                                                                                                                                                                                                                                                                     |  |  |  |
|              | 1 Parity errors cause the appropriate bit in the PCI Express status register to be set. However, note that errors are reported based on the values set in the PCI Express error enable and detection registers.                                                                                                                                                                 |  |  |  |
| 5–3<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| 2            | Indicates whether this PCI Express device is configured as a master.                                                                                                                                                                                                                                                                                                            |  |  |  |
| Bus_master   | EP mode: Clearing this bit prevents the device from issuing any memory or I/O transactions. Because MSI interrupts are effectively memory writes, clearing this bit also disables the ability of the device to issue MSI interrupts.                                                                                                                                            |  |  |  |
|              | RC mode: Clearing this bit disables the ability of the device to forward memory transactions upstream. This causes any inbound memory transaction (except those targeting PEXCSRBAR) to be treated as an unsupported request. Note that this description does not apply for inbound memory transactions targeting PEXCSRBAR which are forwarded if the Memory_space bit is set. |  |  |  |
|              | 0 Disables the ability to generate PCI Express accesses                                                                                                                                                                                                                                                                                                                         |  |  |  |
|              | 1 Enables this PCI Express controller to behave as a PCI Express bus master                                                                                                                                                                                                                                                                                                     |  |  |  |
| 1            | Controls whether this PCI Express device (as a target) responds to memory accesses.                                                                                                                                                                                                                                                                                             |  |  |  |
| Memory_space | EP mode: Clearing this bit prevents the device from accepting any memory transaction.                                                                                                                                                                                                                                                                                           |  |  |  |
|              | RC mode: This bit is ignored for inbound memory transactions except those targeting PEXCSRBAR. Clearing this bit prevents the chip from accepting inbound memory transactions to PEXCSRBAR. This bit does not affect outbound memory transactions.                                                                                                                              |  |  |  |
|              | 0 This PCI Express device does not respond to PCI Express memory space accesses.                                                                                                                                                                                                                                                                                                |  |  |  |
|              | 1 This PCI Express device responds to PCI Express memory space accesses.                                                                                                                                                                                                                                                                                                        |  |  |  |
| 0            | I/O space.                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| I_O_space    | EP mode: Clearing this bit prevents the device from accepting any IO transaction. Note that this bit is a don't care in EP mode since the device does not support IO transaction.                                                                                                                                                                                               |  |  |  |
|              | RC mode: This bit is ignored. It does not affect outbound IO transaction.                                                                                                                                                                                                                                                                                                       |  |  |  |
|              | This PCI Express device (as a target) does not respond to PCI Express I/O space accesses.      This PCI Express device (as a target) does respond to PCI Express I/O space accesses.                                                                                                                                                                                            |  |  |  |

# 14.8.4 PCI Express Status Register (Status\_Register)

The status register is used to record status information for PCI Express related events.





### Status\_Register field descriptions

| Field                                 | Description                                                                                                                                                                                                                                                                            |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>Detected_parity_<br>error       | Set whenever a device receives a poisoned TLP regardless of the state of bit 6 in the command register. <sup>3</sup>                                                                                                                                                                   |
| 14<br>Signaled_<br>system_error       | Set whenever a device sends a ERR_FATAL or ERR_NONFATAL message and the SERR enable bit in the command register is set. <sup>2</sup>                                                                                                                                                   |
| 13<br>Received_<br>master_abort       | Set whenever a requestor receives a completion with unsupported request completion status. <sup>2</sup>                                                                                                                                                                                |
| 12<br>Received_target_<br>abort       | Set whenever a device receives a completion with completer abort completion status. <sup>2</sup>                                                                                                                                                                                       |
| 11<br>Signaled_target_<br>abort       | Set whenever a device completes a request using completer abort completion status. <sup>2</sup>                                                                                                                                                                                        |
| 10–9<br>-                             | This field is reserved. Reserved                                                                                                                                                                                                                                                       |
| 8 Master_data_ parity_error_ detected | Set by the requestor (primary side for Type1 headers) when either the requestor receives a completion marked poisoned or the requestor poisons a write request. Note that the parity error enable bit (bit 6) in the command register must be set for this bit to be set. <sup>2</sup> |

### Status\_Register field descriptions (continued)

| Field                 | Description                                                                                                                                                       |  |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7–5<br>-              | This field is reserved. Reserved                                                                                                                                  |  |
| 4 Capabilities_List   | All PCI Express devices are required to implement the PCI Express capability structure.                                                                           |  |
| 3<br>Interrupt_Status | Set when an INTx interrupt message is pending internally to the device.  Note that this bit is associated with INTx messages and not Message Signaled Interrupts. |  |
| 2–0<br>-              | This field is reserved. Reserved                                                                                                                                  |  |

<sup>1.</sup> The error control and status bits in the command and status registers control PCI-compatible error reporting. PCI Express advanced error reporting is controlled by the PCI Express device control register described in PCI Express Device Control Register (Device\_Control\_Register), and the advance error reporting capability structure described in sections PCI Express Advanced Error Reporting Capability ID Register (Advanced\_Error\_Reporting\_Capability\_ID\_Register) through PCI Express Error Source ID Register (Error\_Source\_ID\_Register).

# 14.8.5 PCI Express Revision ID Register (Revision\_ID\_Register)

The revision ID register is used to identify the revision of the device.





#### Revision\_ID\_Register field descriptions

| Field       | Description        |
|-------------|--------------------|
| 7–0         | Revision specific. |
| Revision_ID |                    |

# 14.8.6 PCI Express Class Code Register (Class\_Code\_Register)

The class code register is comprised of three single-byte fields-base class (offset 0x0B), sub-class (offset 0x0A), and programming interface (offset 0x09)-that indicate the basic functionality of the function.

#### NOTE

See bitfield description table for Programming\_Interface reset value.

#### Type 0 configuration header registers

Address: 9h



### Class\_Code\_Register field descriptions

| Field                      |              | Description        |
|----------------------------|--------------|--------------------|
| 23-16<br>Base_Class        | 0x0B         | Processor          |
| 15–8<br>Sub_Class          | 0x20         | PowerPC            |
| 7–0 Programming_ Interface | 0x00<br>0x01 | RC mode<br>EP mode |

# 14.8.7 PCI Express Cache Line Size Register (Cache\_Line\_Size\_Register)

The cache line size register is provided for legacy compatibility purposes (PCI 2.3); it is not used for PCI Express device functionality.

Address: Ch



## Cache\_Line\_Size\_Register field descriptions

| Field           | Description                                                                                                |
|-----------------|------------------------------------------------------------------------------------------------------------|
| 7–0             | Represents the cache line size of the processor in terms of 32-bit words (8 32-bit words = 32 bytes). Note |
| Cache_Line_Size | that for PCI Express operation this register is ignored.                                                   |

# 14.8.8 PCI Express Latency Timer Register (Latency\_Timer\_Register)

The latency timer register is provided for legacy compatibility purposes (PCI 2.3); it is not used for PCI Express device functionality.



Latency\_Timer\_Register field descriptions

|      | Field             | Description                                                   |
|------|-------------------|---------------------------------------------------------------|
| Late | 7–0<br>ency_Timer | Note that for PCI Express operation this register is ignored. |

# 14.8.9 PCI Express Header Type Register (Header\_Type\_Register)

The PCI Express header type register is used to identify the layout of the PCI compatible header.

### **NOTE**

See bitfield description table for reset value.



Header\_Type\_Register field descriptions

| Field         | Description                                             |
|---------------|---------------------------------------------------------|
|               | Identifies whether a device supports multiple functions |
| Multifunction | 0 Single function device                                |
|               | 1 Multiple function device                              |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## Header\_Type\_Register field descriptions (continued)

| Field         | Description                                                                     |  |
|---------------|---------------------------------------------------------------------------------|--|
| 6–0           | All other encodings reserved.                                                   |  |
| Header_Layout |                                                                                 |  |
|               | 0x00 Endpoint. See Type 0 configuration header registers for type 0 layout.     |  |
|               | 0x01 Root Complex. See Type 1 configuration header registers for type 1 layout. |  |

# 14.8.10 PCI Express Base Address Register 0 (PEXCSRBAR)

The PCI Express base address registers (BARs) point to the beginning of distinct address ranges which the device should claim. In EP mode, the device supports a configuration space BAR, a 32-bit memory space BAR, and two 64-bit memory space BARs. In RC mode, the device only supports the configuration space BAR in the header; the other memory spaces are defined by the inbound ATMUs. Refer to PCI Express inbound ATMUs for more information.

Base address register 0, also known as the PCI Express configuration and status register base address register (PEXCSRBAR), at offset 0x10 is a special fixed 1 -Mbyte window that is used for inbound configuration accesses. Note that PEXCSRBAR cannot be updated through the inbound ATMU registers.





PEXCSRBAR field descriptions

| Field            | Field Description                                                                                           |  |
|------------------|-------------------------------------------------------------------------------------------------------------|--|
| 31–20<br>ADDRESS | Indicates the base address that the inbound configuration window occupies. This window is fixed at 1 Mbyte. |  |
| 19–4<br>-        | This field is reserved. Reserved                                                                            |  |
| 3<br>PREF        | Prefetchable                                                                                                |  |
| 2–1<br>TYPE      | Type.  00 Locate anywhere in 32-bit address space.                                                          |  |
| 0<br>MemSp       | Memory space indicator                                                                                      |  |

## 14.8.11 PCI Express Base Address Register 1 (BAR1)

This register is supported only for EP mode.

The PCI Express base address registers (BARs) point to the beginning of distinct address ranges which the device should claim. In EP mode, the device supports a configuration space BAR, a 32-bit memory space BAR, and two 64-bit memory space BARs. Refer to PCI Express inbound ATMUs for more information.

Base address register 1 at offset 0x14 is used to define the inbound memory window in the 32-bit memory space.



| Field            | Description                                                                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–12<br>ADDRESS | Indicates the base address where the inbound memory window begins. The number of upper bits that the device allows to be writable is selected through the inbound window size in the inbound window attributes register (PEXIWAR1). |
| 11–4<br>-        | This field is reserved. Reserved. The device allows a 4 Kbyte window minimum.                                                                                                                                                       |
| 3<br>PREF        | Prefetchable. This bit is determined by PEXIWAR1[PF].                                                                                                                                                                               |
| 2–1<br>TYPE      | Type.  00 Locate anywhere in 32-bit address space.                                                                                                                                                                                  |
| 0<br>MemSp       | Memory space indicator.                                                                                                                                                                                                             |

# 14.8.12 PCI Express Base Address Register 2,4 (BARn)

This register is supported only for EP mode.

The PCI Express base address registers (BARs) point to the beginning of distinct address ranges which the device should claim. In EP mode, the device supports a configuration space BAR, a 32-bit memory space BAR, and two 64-bit memory space BARs. In RC mode, the device only supports the configuration space BAR in the header; the other memory spaces are defined by the inbound ATMUs. Refer to PCI Express inbound ATMUs, for more information.

Base address register 2 at offset 0x18 and base address register 4 at offset 0x20 are used to define the lower portion of the 64-bit inbound memory windows.



| Field            | Description                                                                                                                                                                                                                                                                                      |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–12<br>ADDRESS | Indicates the lower portion of the base address where the inbound memory window begins. The number of bits that the device allows to be writable is selected through the inbound window size in the inbound window attributes registers (PEXIWAR2 for offset 0x18 and PEXIWAR3 for offset 0x20). |
| 11–4<br>-        | This field is reserved. Reserved. The device allows a 4 Kbyte window minimum.                                                                                                                                                                                                                    |
| 3<br>PREF        | Prefetchable. This bit is determined by PEXIWAR $n$ [2].                                                                                                                                                                                                                                         |

Table continues on the next page...

#### BARn field descriptions (continued)

| Field       | Description                                   |
|-------------|-----------------------------------------------|
| 2–1<br>TYPE | Type.                                         |
|             | 0b10 Locate anywhere in 64-bit address space. |
| 0<br>MemSp  | Memory space indicator                        |

### 14.8.13 PCI Express Base Address Register 3,5 (BARn)

This register is supported only for EP mode.

The PCI Express base address registers (BARs) point to the beginning of distinct address ranges which the device should claim. In EP mode, the device supports a configuration space BAR, a 32-bit memory space BAR, and two 64-bit memory space BARs. In RC mode, the device only supports the configuration space BAR in the header; the other memory spaces are defined by the inbound ATMUs. Refer to PCI Express inbound ATMUs, for more information.

Base address register 3 at offset 0x1C and base address register 5 at offset 0x24 are used to define the upper portion of the 64-bit inbound memory windows.



### BAR*n* field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDRESS | Indicates the upper portion of the base address where the inbound memory window begins. The number of bits that the device allows to be writable is selected through the inbound window size in the inbound window attributes registers (PEXIWAR2 for offset 0x1C and PEXIWAR3 for offset 0x24). If no access to local memory is to be permitted by external requestors, then all bits are programmed. |

## 14.8.14 PCI Express Subsystem Vendor ID Register (Subsystem\_Vendor\_ID\_Register)

This register is supported only for EP mode.

The PCI Express subsystem vendor ID register is used to identify the subsystem.

#### **NOTE**

Reset value taken from PEX\_SSVID\_UPDATE[SS\_ID].

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Address: 2Ch



#### Subsystem\_Vendor\_ID\_Register field descriptions

| Field | Field Description                                                                                                                                                                                                        |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| , –   | The value for subsystem vendor ID is determined by the PCI Express subsystem vendor ID update register. See PCI Express Subsystem Vendor ID Update Register (Subsystem_Vendor_ID_Update_Register), for more information. |  |

### 14.8.15 PCI Express Subsystem ID Register (Subsystem\_ID\_Register)

This register is supported only for EP mode.

The PCI Express subsystem ID register is used to identify the subsystem.

### **NOTE**

Reset value taken from PEX\_SSVID\_UPDATE[SSV\_ID].

#### Address: 2Eh



### Subsystem\_ID\_Register field descriptions

|   | Field | Description                                                                                                   |
|---|-------|---------------------------------------------------------------------------------------------------------------|
| Ī |       | The value for subsystem ID is determined by the PCI Express subsystem vendor ID update register. See          |
|   | -     | PCI Express Subsystem Vendor ID Update Register (Subsystem_Vendor_ID_Update_Register) , for more information. |
| L |       |                                                                                                               |

## 14.8.16 Capabilities Pointer Register (Capabilities\_Pointer\_Register)

The capabilities pointer identifies additional functionality supported by the device.



#### Capabilities\_Pointer\_Register field descriptions

| Field | Description                                                                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | The capabilities pointer provides the offset (0x44) for additional PCI-compatible registers above the common 64-byte header. Refer to PCI compatible device-specific configuration space for more information. |

### 14.8.17 PCI Express Interrupt Line Register (Interrupt\_Line\_Register)

This register is supported only for EP mode.

The interrupt line register is used by device drivers and OS software to communicate interrupt line routing information. Values in this register are programmed by system software and are system specific.



### Interrupt\_Line\_Register field descriptions

|   | Field          | Description                                             |
|---|----------------|---------------------------------------------------------|
| Ī | 7–0            | Used to communicate interrupt line routing information. |
|   | Interrupt_Line |                                                         |

## 14.8.18 PCI Express Interrupt Pin Register (Interrupt\_Pin\_Register)

The interrupt pin register identifies the legacy interrupt (INTx) messages the device (or function) uses.

This register only applies to EP mode.



<sup>\*</sup> Notes:

### Interrupt\_Pin\_Register field descriptions

| Field         | Description                                                     |
|---------------|-----------------------------------------------------------------|
| 7–0           | Legacy INTx message used by this device.                        |
| Interrupt_pin | All other settings Reserved.                                    |
|               | 0x00 This device does not use legacy interrupt (INTx) messages. |
|               | 0x01 INTA                                                       |
|               | 0x02 INTB                                                       |
|               | 0x03 INTC                                                       |
|               | 0x04 INTD                                                       |

# 14.8.19 PCI Express Minimum Grant Register (Minimum\_Grant\_Register)

This register is supported only for EP mode.

This register does not apply to PCI Express. It is present for legacy purposes.



<sup>•</sup> Reset value is 0x00 for RC mode and 0x01 for EP mode.

#### Minimum\_Grant\_Register field descriptions

| Field          | Description                     |
|----------------|---------------------------------|
| 7–0<br>MIN_GNT | Does not apply for PCI Express. |

### 14.8.20 PCI Express Maximum Latency Register (Maximum\_Latency\_Register)

This register is supported only for EP mode.

This register does not apply to PCI Express. It is present for legacy purposes.



### Maximum\_Latency\_Register field descriptions

| Field          | Description                     |  |
|----------------|---------------------------------|--|
| 7–0<br>MAX_LAT | Does not apply for PCI Express. |  |
| IVIAA_LA I     |                                 |  |

### 14.9 Type 1 configuration header registers

The figure below shows the type 1 header.

#### NOTE

The first 16 bytes of the type 1 header are identical to the type 0 header. See Type 0 configuration header registers for descriptions of those registers. This section describes the registers that are unique to the type 1 header beginning at offset 0x10.

#### NOTE

The BIST register (0x0F) is optional and reserved on the PCI Express controller.

| Device ID                        |                        | Vende                | or ID                |
|----------------------------------|------------------------|----------------------|----------------------|
| St                               | atus                   | Com                  | mand                 |
|                                  | Class Code             |                      | Revision ID          |
| BIST                             | Header Type            | Latency Timer        | Cache Line Size      |
|                                  | Base Addre             | ess Register 0       |                      |
|                                  |                        |                      |                      |
| Second Latency Timer             | Subordinate Bus Number | Secondary Bus Number | Primary Bus Number   |
| Seconda                          | ry Status              | I/O Limit            | I/O Base             |
| Memo                             | ry Limit               | Memor                | y Base               |
| Prefetchable                     | Memory Limit           | Prefetchable N       | Memory Base          |
|                                  | Prefetchable Ba        | se Upper 32 Bits     |                      |
| Prefetchable Limit Upper 32 Bits |                        |                      |                      |
| I/O Limit upper 16 Bits          |                        | I/O Base U           | pper 16 Bits         |
|                                  |                        |                      | Capabilities Pointer |
|                                  | Expansion ROM          | / Base Address       |                      |
|                                  |                        |                      |                      |

Figure 14-202. PCI Express PCI-Compatible Configuration Header—Type 1

#### NOTE

The secondary latency timer register (0x1B) does not apply to PCI Express. It must be read-only and return all zeros when read.

### 14.9.1 PCI Express Base Address Register 0 (PEXCSRBAR)

Base address register 0, also known as the PCI Express configuration and status register base address register (PEXCSRBAR), at offset 0x10 is a special fixed 1 -Mbyte window that is used for inbound configuration accesses.

Note that PEXCSRBAR cannot be updated through the inbound ATMU registers.

Type 1 configuration header registers

Address: 10h



### **PEXCSRBAR** field descriptions

| Field            | Description                                                                                                 |  |
|------------------|-------------------------------------------------------------------------------------------------------------|--|
| 31–20<br>ADDRESS | Indicates the base address that the inbound configuration window occupies. This window is fixed at 1 Mbyte. |  |
| 19–4<br>-        | This field is reserved. Reserved                                                                            |  |
| 3<br>PREF        | Prefetchable                                                                                                |  |
| 2–1<br>TYPE      | Type.  00 Locate anywhere in 32-bit address space.                                                          |  |
| 0<br>MemSp       | Memory space indicator                                                                                      |  |

### 14.9.2 PCI Express Primary Bus Number Register (Primary\_Bus\_Number\_Register)





### Primary Bus Number Register field descriptions

| Field | Description                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Bus that is connected to the upstream interface. Note that this register is programmed during system enumeration; in RC mode this register should remain 0x00. |

## 14.9.3 PCI Express Secondary Bus Number Register (Secondary\_Bus\_Number\_Register)

Address: 19h



### Secondary\_Bus\_Number\_Register field descriptions

| Field | Description                                                                                                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Bus that is directly connected to the downstream interface. Note that this register is programmed during system enumeration; in RC mode, this register is typically programmed to 0x01. |

## 14.9.4 PCI Express Subordinate Bus Number Register (Subordinate\_Bus\_Number\_Register)

Address: 1Ah



### Subordinate\_Bus\_Number\_Register field descriptions

| Field                             | Description                                             |
|-----------------------------------|---------------------------------------------------------|
| 7-0<br>Subordinate_<br>Bus_Number | Highest bus number that is on the downstream interface. |

### 14.9.5 PCI Express I/O Base Register (IO\_Base\_Register)

Note that this device does not support inbound I/O transactions.





### IO\_Base\_Register field descriptions

| Field                   | Description                                                                   |
|-------------------------|-------------------------------------------------------------------------------|
| 7–4                     | Specifies bits 15:12 of the I/O space start address.                          |
| IO_Start_<br>Address    | NOTE: I/O Start Address is writeable in root complex, read-only in end point. |
| 3–0                     | Specifies the number of I/O address bits.                                     |
| Address_<br>Decode_Type | All other settings reserved.                                                  |
|                         | 0x00 16-bit I/O address decode                                                |
|                         | 0x01 32-bit I/O address decode                                                |

### 14.9.6 PCI Express I/O Limit Register (IO\_Limit\_Register)

Note that this device does not support inbound I/O transactions.

Address: 1Dh



### IO\_Limit\_Register field descriptions

| Field                          | Description                                                             |
|--------------------------------|-------------------------------------------------------------------------|
| 7–4<br>IO_Limit_<br>Address    | Specifies bits 15:12 of the I/O space ending address                    |
| 3–0<br>Address_<br>Decode_Type | Specifies the number of I/O address bits.  All other settings reserved. |
|                                | 0x00 16-bit I/O address decode<br>0x01 32-bit I/O address decode        |

## 14.9.7 PCI Express Secondary Status Register (Secondary\_Status\_Register)

Note that the errors in this register may be masked by corresponding bits in the secondary status interrupt mask register (PEX\_SS\_INTR\_MASK) and that by default all of the errors are masked. See Secondary Status Interrupt Mask Register (Secondary Status Interrupt Mask Register) for more information.

Address: 1Eh



#### Secondary\_Status\_Register field descriptions

| Field     | Description                                                                                                                                                                      |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>DPE | Detected parity error. This bit is set whenever the secondary side receives a poisoned TLP regardless of the state of the parity error response bit.                             |
| 14<br>SSE | Signaled system error. This bit is set when a device sends a ERR_FATAL or ERR_NONFATAL message, provided the SERR enable bit in the command register is set to enable reporting. |
| 13<br>RMA | Received master abort. This bit is set when the secondary side receives an unsupported request (UR) completion.                                                                  |
| 12<br>RTA | Received target abort. This bit is set when the secondary side receives a completer abort (CA) completion.                                                                       |

Table continues on the next page...

#### Type 1 configuration header registers

### Secondary\_Status\_Register field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                         |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11<br>STA | Signaled target abort. This bit is set when the secondary side issues a CA completion.                                                                                                                                                              |
| 10–9<br>- | This field is reserved. Reserved                                                                                                                                                                                                                    |
| 8<br>MDPE | Master data parity error. This bit is set when the parity error response bit is set and the secondary side requestor receives a poisoned completion or poisons a write request. If the parity error response bit is cleared, this bit is never set. |
| 7–0<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                    |

# 14.9.8 PCI Express Memory Base Register (Memory\_Base\_Register)

Address: 20h



#### Memory\_Base\_Register field descriptions

| Field               | Description                                                                                                                                                                                            |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–4<br>Memory_Base | Specifies bits 31:20 of the non-prefetchable memory space start address. Typically used for specifying memory-mapped I/O space.                                                                        |
|                     | NOTE: Inbound posted transactions hitting into the mem base/limit range are ignored; inbound non-posted transactions hitting into the mem base/limit range results in an unsupported request response. |
| 3–0<br>-            | This field is reserved. Reserved                                                                                                                                                                       |

# 14.9.9 PCI Express Memory Limit Register (Memory\_Limit\_Register)

Address: 22h



### Memory\_Limit\_Register field descriptions

| Field                | Description                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–4<br>Memory_Limit | Specifies bits 31:20 of the non-prefetchable memory space ending address. Typically used for specifying memory-mapped I/O space.                                                                    |
|                      | NOTE: Inbound posted transactions hitting into the mem base/limit range are ignored; inbound non-posted transactions hitting into the mem base/limit range results in unsupported request response. |
| 3–0                  | This field is reserved.                                                                                                                                                                             |
| -                    | Reserved                                                                                                                                                                                            |

### 14.9.10 PCI Express Prefetchable Memory Base Register (Prefetchable\_Memory\_Base\_Register)





#### Prefetchable\_Memory\_Base\_Register field descriptions

| Field                          | Description                                                                                                                                                                                         |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–4                           | Specifies bits 31:20 of the prefetchable memory space start address.                                                                                                                                |
| PF_Memory_<br>Base             | NOTE: Inbound posted transactions hitting into the mem base/limit range are ignored; inbound non-posted transactions hitting into the mem base/limit range results in unsupported request response. |
| 3–0<br>Address_<br>Decode_Type | Specifies the number of prefetchable memory address bits.  All other settings reserved.                                                                                                             |
|                                | 0x00 32-bit memory address decode 0x01 64-bit memory address decode                                                                                                                                 |

# 14.9.11 PCI Express Prefetchable Memory Limit Register (Prefetchable\_Memory\_Limit\_Register)





#### Type 1 configuration header registers

### Prefetchable\_Memory\_Limit\_Register field descriptions

| Field                   | Description                                                                                                                                                                                         |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–4                    | Specifies bits 31:20 of the prefetchable memory space ending address.                                                                                                                               |
| PF_Memory_<br>Limit     | NOTE: Inbound posted transactions hitting into the mem base/limit range are ignored; inbound non-posted transactions hitting into the mem base/limit range results in unsupported request response. |
| 3–0                     | Specifies the number of prefetchable memory address bits.                                                                                                                                           |
| Address_<br>Decode_Type | All other settings reserved.                                                                                                                                                                        |
|                         | 0x00 32-bit memory address decode                                                                                                                                                                   |
|                         | 0x01 64-bit memory address decode                                                                                                                                                                   |

### 14.9.12 PCI Express Prefetchable Base Upper 32 Bits Register (Prefetchable\_Base\_Upper\_32\_Bits\_Register)

Address: 28h



### Prefetchable\_Base\_Upper\_32\_Bits\_Register field descriptions

| Field | Description                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Specifies bits 64:32 of the prefetchable memory space start address when the address decode type field in the prefetchable memory base register is 0x01. |

## 14.9.13 PCI Express Prefetchable Limit Upper 32 Bits Register (Prefetchable\_Limit\_Upper\_32\_Bits\_Register)

Address: 2Ch



### Prefetchable\_Limit\_Upper\_32\_Bits\_Register field descriptions

| Field | Description                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Specifies bits 64-32 of the prefetchable memory space ending address when the address decode type field in the prefetchable memory limit register is 0x01. |

## 14.9.14 PCI Express I/O Base Upper 16 Bits Register (IO\_Base\_Upper\_16\_Bits\_Register)

Note that this device does not support inbound I/O transactions.

#### NOTE

Access is read/write in root complex and read only in endpoint.



### IO\_Base\_Upper\_16\_Bits\_Register field descriptions

| Field                             | Description                                                                                                              |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>IO_Base_Upper_<br>16_Bits | Specifies bits 31-16 of the I/O space start address when the address decode type field in the I/O base register is 0x01. |

### 14.9.15 PCI Express I/O Limit Upper 16 Bits Register (IO\_Limit\_Upper\_16\_Bits\_Register)

Note that this device does not support inbound I/O transactions.

#### NOTE

Access is read/write in root complex and read only in endpoint.



### IO\_Limit\_Upper\_16\_Bits\_Register field descriptions

| Field                              | Description                                                                                                                |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>IO_Limit_Upper_<br>16_Bits | Specifies bits 31-16 of the I/O space ending address when the address decode type field in the I/O limit register is 0x01. |

## 14.9.16 Capabilities Pointer Register (Capabilities\_Pointer\_Register)

The capabilities pointer identifies additional functionality supported by the device.



#### Capabilities\_Pointer\_Register field descriptions

| Field         | Description                                                                                                                                                                                                    |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Capabilities_ | The capabilities pointer provides the offset (0x44) for additional PCI-compatible registers above the common 64-byte header. Refer to PCI compatible device-specific configuration space for more information. |

### 14.9.17 PCI Express Interrupt Line Register (Interrupt\_Line\_Register)

This register only applies to endpoint mode.

The interrupt line register is used by device drivers and OS software to communicate interrupt line routing information. Values in this register are programmed by system software and are system specific.



### Interrupt\_Line\_Register field descriptions

|   | Field          | Description                                             |
|---|----------------|---------------------------------------------------------|
| Ī | 7–0            | Used to communicate interrupt line routing information. |
|   | Interrupt_Line |                                                         |

## 14.9.18 PCI Express Interrupt Pin Register (Interrupt\_Pin\_Register)

The interrupt pin register identifies the legacy interrupt (INTx) messages the device (or function) uses when configured in EP mode.

This register only applies to EP mode.



<sup>\*</sup> Notes:

#### Interrupt\_Pin\_Register field descriptions

| Field         | Description                                                     |
|---------------|-----------------------------------------------------------------|
| 7–0           | Legacy INTx message used by this device.                        |
| Interrupt_pin | All other settings reserved.                                    |
|               | 0x00 This device does not use legacy interrupt (INTx) messages. |
|               | 0x01 INTA                                                       |
|               | 0x02 INTB                                                       |
|               | 0x03 INTC                                                       |
|               | 0x04 INTD                                                       |

# 14.9.19 PCI Express Bridge Control Register (Bridge\_Control\_Register)





<sup>•</sup> Reset value is 0x00 for RC mode and 0x01 for EP mode.

### PCI compatible device-specific configuration space

### **Bridge\_Control\_Register field descriptions**

| Field         | Description                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------|
| 15–7<br>-     | This field is reserved. Reserved                                                                                                 |
| 6<br>Scnd_RST | Secondary bus reset                                                                                                              |
| 5–4<br>-      | This field is reserved. Reserved                                                                                                 |
| 3<br>VGA_EN   | VGA enable                                                                                                                       |
| 2<br>ISA_EN   | ISA enable                                                                                                                       |
| 1<br>SERR_EN  | SERR enable. This bit controls the propagation of ERR_COR, ERR_NONFATAL, and ERR_FATAL responses received on the secondary side. |
| 0<br>PER      | Parity error response.                                                                                                           |

### 14.10 PCI compatible device-specific configuration space

The PCI compatible device-specific configuration space is a PCI compatible configuration space from 0x40 to 0xFF (just after the 64-byte PCI-compatible configuration header).

| Reserved        |                   |                                                  | Add<br>Offset (           | Н |
|-----------------|-------------------|--------------------------------------------------|---------------------------|---|
|                 | PCI-Compatible Co | nfiguration Header                               |                           | C |
|                 |                   |                                                  |                           | 3 |
| Power Mgm       | Capabilities      | Next Pointer (0x4C)                              | Power Mgmt Capability ID  | 4 |
| Data            |                   | Power Managem                                    | ent Status & Control      | 4 |
| PCI Expres      | es Capabilities   | Next Pointer<br>(0x70—EP mode)<br>(NULL—RC mode) | PCI Express Capability ID | 4 |
|                 | Device Ca         | pabilities                                       |                           | 5 |
| Device          | Status            | Devic                                            | e Control                 | 5 |
|                 | Link Ca           | pabilities                                       |                           | 5 |
| Link S          | tatus             | Lin                                              | k Control                 | 5 |
|                 | Slot Capabilities | (RC mode only)                                   |                           | 6 |
| Slot Status (Ro | C mode only)      | Slot Contro                                      | ol (RC mode only)         | 6 |
|                 |                   | Root Contr                                       | ol (RC mode only)         | 6 |
|                 | Root              | Status                                           |                           | 6 |
| MSI Messa       | ge Control        | Next Pointer (NULL)                              | MSI Message Capability ID | 7 |
|                 | MSI Messa         | age Address                                      |                           | 7 |
|                 | MSI Upper Me      | essage Address                                   |                           | 7 |
|                 |                   | MSI N                                            | lessage Data              | 7 |
|                 |                   |                                                  |                           | 8 |
|                 |                   |                                                  |                           | F |

Figure 14-222. PCI Compatible Device-Specific Configuration Space

## 14.10.1 PCI Express Power Management Capability ID Register (Power\_Management\_Capability\_ID\_Register)





#### Power\_Management\_Capability\_ID\_Register field descriptions

| Field                         | Description             |
|-------------------------------|-------------------------|
| 7–0 Power_Mgmt_ Capability_ID | Power Management = 0x01 |

## 14.10.2 PCI Express Power Management Capabilities Register (Power\_Management\_Capabilities\_Register)

Address: 46h



<sup>\*</sup> Notes:

### Power\_Management\_Capabilities\_Register field descriptions

| Field                | Description                                          |
|----------------------|------------------------------------------------------|
| 15–11<br>PME_Support | Indicates the power states that this device supports |
| 10<br>D2             | D2 Support                                           |
| 9<br>D1              | D1 Support                                           |

Table continues on the next page...

<sup>•</sup> PME\_Support field: Reset value is 11111 in RC mode and 01111 in EP mode.

### Power\_Management\_Capabilities\_Register field descriptions (continued)

| Field           | Description                                      |
|-----------------|--------------------------------------------------|
| 8–6<br>AUX_Curr | AUX Current                                      |
| 5<br>DSI        | Device Specific Initialization                   |
| 4 -             | This field is reserved. Reserved                 |
| 3<br>PME_CLK    | Does not apply to PCI Express.                   |
| 2–0<br>Version  | Setting depends on version of the specification. |

# 14.10.3 PCI Express Power Management Status and Control Register

(Power\_Management\_Status\_and\_Control\_Register)





### Power\_Management\_Status\_and\_Control\_Register field descriptions

| Field               | Description                                                     |
|---------------------|-----------------------------------------------------------------|
| 15<br>PME_STAT      | PME Status                                                      |
| 14–13<br>Data_Scale | Obtained directly from the PCI Express Base Specification .     |
| 12–9<br>Data_Select | Obtained directly from the PCI Express Base Specification .     |
| 8                   | PME Enable                                                      |
| PME_EN              | NOTE: Bitfield access is sticky.                                |
| 7–2<br>-            | This field is reserved. Reserved                                |
| 1–0                 | Power state. Indicates the current power state of the function. |
| Power_State         | 0x00 D0                                                         |

Table continues on the next page...

### Power\_Management\_Status\_and\_Control\_Register field descriptions (continued)

| Field | Description |
|-------|-------------|
|       | 0x01 D1     |
|       | 0x02 D2     |
|       | 0x03 D3     |

## 14.10.4 PCI Express Power Management Data Register (Power\_Management\_Data\_Register)





#### Power\_Management\_Data\_Register field descriptions

| Field | Description                                                 |
|-------|-------------------------------------------------------------|
| 7–0   | Obtained directly from the PCI Express Base Specification . |
| Data  |                                                             |

## 14.10.5 PCI Express Capability ID Register (Capability\_ID\_Register)

Address: 4Ch



### Capability\_ID\_Register field descriptions

| Field                          | Description        |
|--------------------------------|--------------------|
| 7-0 PCI_Express_ Capability_ID | PCI Express = 0x10 |

### 14.10.6 PCI Express Capabilities Register (Capabilities\_Register)

Address: 4Eh



<sup>\*</sup> Notes:

### Capabilities\_Register field descriptions

| Field                                    | Description                                                                                                                                                                                                                                                                                                                        |  |  |  |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 15–14<br>-                               | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                   |  |  |  |
| 13–9<br>Interrupt_<br>Message_<br>Number | If this function is allocated more than one MSI interrupt number, then this register is required to contain the offset between the base Message Data and the MSI Message that is generated when any of the status bits in either the Slot Status register or the Root Port Status register, of this capability structure, are set. |  |  |  |
| 8<br>Slot                                | Slot Implemented (RC mode only)                                                                                                                                                                                                                                                                                                    |  |  |  |
| 7–4<br>Device_Port_<br>Type              | 0100 (RC mode)<br>0000 (EP mode)                                                                                                                                                                                                                                                                                                   |  |  |  |
| 3–0<br>Capability_<br>Version            | Indicates the defined PCI Express capability structure version number. Must be 1h for 1.0, 1.0a, and 1.1 specification.                                                                                                                                                                                                            |  |  |  |

<sup>•</sup> Device\_Port\_Type field: Reset value depends on mode: 0100 (RC mode), 0000 (EP mode)

## 14.10.7 PCI Express Device Capabilities Register (Device\_Capabilities\_Register)

Refer to PCI Express Base Specification for register details.



### Device\_Capabilities\_Register field descriptions

| Field                      | Description                                     |
|----------------------------|-------------------------------------------------|
| 31–28<br>-                 | This field is reserved. Reserved                |
| 27–26<br>CSPLS             | Captured Slot Power Limit Scale                 |
| 25–18<br>CSPLV             | Captured Slot Power Limit Value                 |
| 17–15<br>-                 | This field is reserved. Reserved                |
| 14<br>PIP                  | Power Indicator Present                         |
| 13<br>AIP                  | Attention Indicator Present                     |
| 12<br>ABP                  | Attention Button Present                        |
| 11–9<br>EP_L1_LAT          | Endpoint L1 Acceptable Latency                  |
| 8–6<br>EP_L0s_LAT          | Endpoint L0s Acceptable Latency                 |
| 5<br>ET                    | Extended Tag Field Supported                    |
| 4–3<br>PHAN_FCT            | Phantom Functions Supported                     |
| 2-0<br>MAX_PL_SIZE_<br>SUP | Maximum payload size supported. 001 = 256-bytes |

# 14.10.8 PCI Express Device Control Register (Device\_Control\_Register)

Address: 54h

| Bit           | 15       | 14        | 13          | 12 | 11  | 10  | 9    | 8   |
|---------------|----------|-----------|-------------|----|-----|-----|------|-----|
| Read<br>Write | Reserved | М         | AX_READ_SIZ | ZE | NSE | APE | PFE  | ETE |
| Reset         | 0        | 0         | 1           | 0  | 1   | 0   | 0    | 0   |
| Bit           | 7        | 6         | 5           | 4  | 3   | 2   | 1    | 0   |
| Read<br>Write | MAX      | _PAYLOAD_ | SIZE        | RO | URR | FER | NFER | CER |
| Reset         | 0        | 0         | 0           | 1  | 0   | 0   | 0    | 0   |

### Device\_Control\_Register field descriptions

| Field                | Description                                                                          |  |  |  |
|----------------------|--------------------------------------------------------------------------------------|--|--|--|
| Field                | Description                                                                          |  |  |  |
| 15                   | This field is reserved.                                                              |  |  |  |
| -                    | Reserved                                                                             |  |  |  |
| 14–12                | Maximum read request size                                                            |  |  |  |
| MAX_READ_<br>SIZE    |                                                                                      |  |  |  |
| 11                   | No snoop enable                                                                      |  |  |  |
| NSE                  | No shoop enable                                                                      |  |  |  |
| 10                   | AUX power PM enable                                                                  |  |  |  |
| APE                  |                                                                                      |  |  |  |
| 9                    | Phantom functions enable                                                             |  |  |  |
| PFE                  |                                                                                      |  |  |  |
| 8                    | Extended tag field enable                                                            |  |  |  |
| ETE                  |                                                                                      |  |  |  |
| 7–5                  | Maximum payload size                                                                 |  |  |  |
| MAX_<br>PAYLOAD_SIZE | 000 For 128 bytes MAX_PAYLOAD_SIZE                                                   |  |  |  |
| 17(120/18_0122       | 001 For 256 bytes MAX_PAYLOAD_SIZE                                                   |  |  |  |
| 4                    | Relaxed ordering                                                                     |  |  |  |
| RO                   | NOTE: Configuration authors are already this hit if valoued audevices is not desired |  |  |  |
|                      | NOTE: Configuration software must clear this bit if relaxed ordering is not desired. |  |  |  |
|                      | 1 Relaxed ordering is enabled.                                                       |  |  |  |
| 3                    | Unsupported request reporting                                                        |  |  |  |
| URR                  |                                                                                      |  |  |  |
| 2                    | Fatal error reporting                                                                |  |  |  |
| FER                  |                                                                                      |  |  |  |
| 1                    | Non-fatal error reporting                                                            |  |  |  |
| NFER                 |                                                                                      |  |  |  |
| 0                    | Correctable error reporting                                                          |  |  |  |
| CER                  |                                                                                      |  |  |  |

# 14.10.9 PCI Express Device Status Register (Device\_Status\_Register)





### Device\_Status\_Register field descriptions

| Field     | Description                      |
|-----------|----------------------------------|
| 15–6<br>- | This field is reserved. Reserved |
| 5<br>TP   | Transactions pending             |
| 4<br>APD  | AUX power detected               |
| 3<br>URD  | Unsupported request detected     |
| 2<br>FED  | Fatal error detected             |
| 1<br>NFED | Non-fatal error detected         |
| 0<br>CED  | Correctable error detected       |

## 14.10.10 PCI Express Link Capabilities Register (Link\_Capabilities\_Register)

#### **NOTE**

See bitfield descriptions for reset values.





### Link\_Capabilities\_Register field descriptions

| Field                | Description                                                                                                                                                                                                                                                                                 |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31–24<br>Port_Number | Port number for PCI Express link                                                                                                                                                                                                                                                            |  |  |  |  |
| 23–18<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                                            |  |  |  |  |
| 17–15<br>L1_EX_LAT   | L1 exit latency  Note that exit latencies may be influenced by PCI Expressreference clock configuration depending upon whether a component uses a common or separate reference clock.  000 Less than 1 μs  001 1 μs to less than 2 μs  010 2 μs to less than 4μs  011 4 μs to less than 8μs |  |  |  |  |
|                      | <ul> <li>100 8 μs to less than 16 μs</li> <li>101 16μs to less than 32μs</li> <li>110 32μs - 64 μs</li> <li>111 More than 64 μs</li> </ul>                                                                                                                                                  |  |  |  |  |
| 14–12<br>LOS_EX_LAT  | Los exit latency  Note that exit latencies may be influenced by PCI Expressreference clock configuration depending upon whether a component uses a common or separate reference clock.  Our Less than 64 ns  Our 64 ns to less than 128 ns                                                  |  |  |  |  |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### Link\_Capabilities\_Register field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                          |  |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                   | 010 128 ns to less than 256 ns                                                                                                                                                                                                                       |  |  |  |  |
|                   | 011 256 ns to less than 512 ns                                                                                                                                                                                                                       |  |  |  |  |
|                   | 100 512 ns to less than 1µs                                                                                                                                                                                                                          |  |  |  |  |
|                   | 101 1 μs to less than 2 μs                                                                                                                                                                                                                           |  |  |  |  |
|                   | 110 2 μs – 4 μs                                                                                                                                                                                                                                      |  |  |  |  |
|                   | 111 More than 4 μs                                                                                                                                                                                                                                   |  |  |  |  |
| 11–10             | Active state power management (ASPM) Support                                                                                                                                                                                                         |  |  |  |  |
| ASPM              | Note: Although this bit field is hard wired to 01 indicating "L0s Entry Supported," this device actually cannot support ASPM. See more detailed description in the ASPM_CTL bit field of PCI Express Link Control Register (Link_Control_Register) . |  |  |  |  |
|                   | 01 L0s entry supported                                                                                                                                                                                                                               |  |  |  |  |
|                   | 11 L0s and L1entry supported                                                                                                                                                                                                                         |  |  |  |  |
| 9–4<br>MAX_LINK_W | Maximum link width. Reset value depends upon the maximum link width of the PCI Express controller is capable of supporting.                                                                                                                          |  |  |  |  |
|                   | 000001 x1                                                                                                                                                                                                                                            |  |  |  |  |
|                   | 000010 x2                                                                                                                                                                                                                                            |  |  |  |  |
|                   | 000100 x4                                                                                                                                                                                                                                            |  |  |  |  |
|                   | 001000 x8                                                                                                                                                                                                                                            |  |  |  |  |
| 3–0               | Maximum link speed                                                                                                                                                                                                                                   |  |  |  |  |
| MAX_LINK_SP       | 0001 2.5 GT/s link                                                                                                                                                                                                                                   |  |  |  |  |

# 14.10.11 PCI Express Link Control Register (Link\_Control\_Register)

Address: 5Ch



### Link\_Control\_Register field descriptions

| Field | Description             |
|-------|-------------------------|
| 15–8  | This field is reserved. |
| -     | Reserved                |

Table continues on the next page...

### Link\_Control\_Register field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7<br>EXT_SYNC   | Extended synch                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| 6<br>CCC        | Common clock configuration                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| 5<br>RL         | Retrain link (Reserved for EP devices). In RC mode, setting this bit initiates link retraining by directing the Physical Layer LTSSM to the Recovery state, if the link has already been up; reads of this bit always return 0.                                                                                                                                                |  |  |  |
| 4<br>LD         | Link disable (Reserved for EP devices)                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| 3<br>RCB        | Read completion boundary                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 2 -             | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| 1–0<br>ASPM_CTL | Active state power management (ASPM) control  NOTE: To ensure correct functionality, the ASPM feature has to be turned off for this device and its link partner by system software at all time. In other words, system software must set this ASPM_CTL bit field to 00 via configuration transaction. The same configuration must be done for the link partner of this device. |  |  |  |

# 14.10.12 PCI Express Link Status Register (Link\_Status\_Register)

Address: 5Eh



### Link\_Status\_Register field descriptions

| Field      | Description                      |  |  |
|------------|----------------------------------|--|--|
| 15–13<br>- | This field is reserved. Reserved |  |  |
| 12<br>SCC  | Slot clock configuration         |  |  |
| 11<br>LT   | Link training                    |  |  |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### Link\_Status\_Register field descriptions (continued)

| Field             | Description                       |  |  |
|-------------------|-----------------------------------|--|--|
| 10<br>-           | This field is reserved. Reserved. |  |  |
| 9–4<br>NEG_LINK_W | Negotiated link width             |  |  |
| 3-0<br>LINK_SP    | Link speed.                       |  |  |

# 14.10.13 PCI Express Slot Capabilities Register (Slot\_Capabilities\_Register)

This register is supported only for RC mode.





Slot\_Capabilities\_Register field descriptions

| Field          | Description                                                                                                  |
|----------------|--------------------------------------------------------------------------------------------------------------|
|                | This hardware initialized field indicates the physical slot number attached to this Port. This field must be |
| Physical_Slot_ | hardware initialized to a value that assigns a slot number that is globally unique within the chassis. These |
| Number         |                                                                                                              |

Table continues on the next page...

### Slot\_Capabilities\_Register field descriptions (continued)

| Field         | Description                                                                                                                                                                                 |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|               | registers should be initialized to 0 for Ports connected to devices that are either integrated on the system board or integrated within the same silicon as the Switch device or Root Port. |  |  |  |
| 18–17<br>-    | This field is reserved. Reserved                                                                                                                                                            |  |  |  |
| 16–15<br>SPLS | Slot power limit scale.                                                                                                                                                                     |  |  |  |
| 14–7<br>SPLV  | Slot power limit value.                                                                                                                                                                     |  |  |  |
| 6<br>HPC      | Hot plug capable.                                                                                                                                                                           |  |  |  |
| 5<br>HPS      | Hot plug surprise.                                                                                                                                                                          |  |  |  |
| 4<br>PIP      | Power indicator present.                                                                                                                                                                    |  |  |  |
| 3<br>AIP      | Attention indicator present.                                                                                                                                                                |  |  |  |
| 2<br>MRLSP    | MRL sensor present.                                                                                                                                                                         |  |  |  |
| 1<br>PCP      | Power controller present.                                                                                                                                                                   |  |  |  |
| 0<br>ABP      | Attention button present.                                                                                                                                                                   |  |  |  |

# 14.10.14 PCI Express Slot Control Register (Slot\_Control\_Register)

This register is supported only for RC mode.

Address: 64h

| Bit           | 15 | 14  | 13       | 12   | 11   | 10     | 9    | 8    |
|---------------|----|-----|----------|------|------|--------|------|------|
| Read<br>Write |    |     | Reserved |      |      | PCC    | Р    | IC   |
| Reset         | 0  | 0   | 0        | 0    | 0    | 0      | 1    | 1    |
| Bit           | 7  | 6   | 5        | 4    | 3    | 2      | 1    | 0    |
| Read<br>Write |    | AIC | HPIE     | CCIE | PDCE | MRLSCE | PFDE | ABPE |
| Reset         | 1  | 1   | 0        | 0    | 0    | 0      | 0    | 0    |

### Slot\_Control\_Register field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15–11<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 10<br>PCC   | Power controller control.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 9–8<br>PIC  | Power indicator control.  If a power indicator is implemented, set the power indicator to the written state. Reads of this field must reflect the value from the latest write, even if the corresponding hot-plug command is not complete, unless software issues a write without waiting for the previous command to complete in which case the read value is undefined. Defined encodings are shown below. |  |  |  |  |
|             | <b>NOTE:</b> The default value of this field must be one of the non-reserved values. If the power indicator present bit in the slot capabilities register is 0, this bit is permitted to be read-only with a value of 00.                                                                                                                                                                                    |  |  |  |  |
|             | 00 Reserved 01 On 10 Blink 11 Off                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| 7–6         | Attention indicator control.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| AIC         | If an attention indicator is implemented, writes to this field set the attention indicator to the written state. Reads of this field must reflect the value from the latest write, even if the corresponding hot-plug command is not complete, unless software issues a write without waiting for the previous command to complete in which case the read value is undefined.                                |  |  |  |  |
|             | <b>NOTE:</b> The default value of this field must be one of the non-reserved values. if the attention indicator present bit in the slot capabilities register is 0, this bit is permitted to be readonly with a value of 00.                                                                                                                                                                                 |  |  |  |  |
|             | 00 Reserved 01 On 10 Blink 11 Off                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| 5<br>HPIE   | Hot plug interrupt enable.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 4<br>CCIE   | Command completed interrupt enable.                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 3<br>PDCE   | Presence detect changed enable.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 2<br>MRLSCE | MRL sensor changed enable.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 1<br>PFDE   | Power fault detected enable.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 0<br>ABPE   | Attention button pressed enable.                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |

### 14.10.15 PCI Express Slot Status Register (Slot\_Status\_Register)

This register is supported only for RC mode.





### Slot\_Status\_Register field descriptions

| Field      | Description                                                                                                                                                                                                    |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 15–7<br>-  | This field is reserved. Reserved                                                                                                                                                                               |  |  |
| 6<br>PDS   | Presence detect state. In the PCI Express specification, this bit indicates the presence of a card in the slot; however, on this device, this bit is set regardless of whether there is a card present or not. |  |  |
|            | 0 Slot empty 1 Card present in slot                                                                                                                                                                            |  |  |
| 5<br>MRLSS | MRL sensor state.  0 MRL closed                                                                                                                                                                                |  |  |
|            | 1 MRL open                                                                                                                                                                                                     |  |  |
| 4<br>CC    | Command completed.                                                                                                                                                                                             |  |  |
| 3<br>PDC   | Presence detect changed.                                                                                                                                                                                       |  |  |
| 2<br>MRLSC | MRL sensor changed.                                                                                                                                                                                            |  |  |
| 1<br>PFD   | Power fault detected.                                                                                                                                                                                          |  |  |
| 0<br>ABP   | Attention button pressed.                                                                                                                                                                                      |  |  |

# 14.10.16 PCI Express Root Control Register (Root\_Control\_Register)

This register is supported only for RC mode.

Address: 68h



### Root\_Control\_Register field descriptions

| Field       | Description                               |  |
|-------------|-------------------------------------------|--|
| 15–4<br>-   | This field is reserved. Reserved          |  |
| 3<br>PMEIE  | PME interrupt enable.                     |  |
| 2<br>SEFEE  | System error on fatal error enable.       |  |
| 1<br>SENFEE | System error on non-fatal error enable.   |  |
| 0<br>SECEE  | System error on correctable error enable. |  |

# 14.10.17 PCI Express Root Status Register (Root\_Status\_Register)

This register is supported only for RC mode.





### Root\_Status\_Register field descriptions

| Field                        | Description                      |  |  |
|------------------------------|----------------------------------|--|--|
| 31–18<br>-                   | This field is reserved. Reserved |  |  |
| 17<br>PMEP                   | PME pending.                     |  |  |
| 16<br>PMES                   | PME status.                      |  |  |
| 15-0<br>PME_Requestor_<br>ID | PME requestor ID.                |  |  |

## 14.10.18 PCI Express MSI Message Capability ID Register (MSI\_Message\_Capability\_ID\_Register)

This register is supported only for EP mode.



MSI\_Message\_Capability\_ID\_Register field descriptions

| Field                                | Description        |
|--------------------------------------|--------------------|
| 7–0<br>MSI_Message_<br>Capability_ID | MSI Message = 0x05 |

## 14.10.19 PCI Express MSI Message Control Register (MSI\_Message\_Control\_Register)

This register is supported only for EP mode.





MSI Message Control Register field descriptions

| Field | Description             |
|-------|-------------------------|
|       | This field is reserved. |
| -     | Reserved                |

Table continues on the next page...

## MSI\_Message\_Control\_Register field descriptions (continued)

| Field      | Description               |
|------------|---------------------------|
| 7<br>64AC  | 64-bit address capable.   |
| 6–4<br>MME | Multiple message enable.  |
| 3–1<br>MMC | Multiple message capable. |
| 0<br>MSIE  | MSI enable.               |

# 14.10.20 PCI Express MSI Message Address Register (MSI\_Message\_Address\_Register)

This register only applies to endpoint mode.

Address: 74h



## MSI\_Message\_Address\_Register field descriptions

| Field                       | Description                                                  |
|-----------------------------|--------------------------------------------------------------|
| 31–2<br>Message_<br>Address | System-specified message address                             |
| 1–0<br>Reserved             | This read-only field is reserved and always has the value 0. |

# 14.10.21 PCI Express MSI Message Upper Address Register (MSI\_Message\_Upper\_Address\_Register)

This register only applies to endpoint mode.

Address: 78h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### PCI Express extended configuration space

## MSI\_Message\_Upper\_Address\_Register field descriptions

| Field                             | Description                            |
|-----------------------------------|----------------------------------------|
| 31-0<br>Message_Upper_<br>Address | System-specified message upper address |

# 14.10.22 PCI Express MSI Message Data Register (MSI\_Message\_Data\_Register)

This register is supported only for EP mode.





### MSI\_Message\_Data\_Register field descriptions

| Field        | Description               |
|--------------|---------------------------|
| 15–0         | System-specified message. |
| Message_Data |                           |

# 14.11 PCI Express extended configuration space

| Reserved                                         | 0                                      | Addres |
|--------------------------------------------------|----------------------------------------|--------|
| PCI-Compatibl                                    | le Configuration Header                | 000    |
|                                                  |                                        | 031    |
|                                                  |                                        | 040    |
| PCI-Compatible Device                            | e-Specific Configuration Space         |        |
|                                                  |                                        | 0FI    |
| Next Capability Offset (NULL)/Capability Version | Advanced Error Reporting Capability ID | 100    |
| Uncorrect                                        | table Error Status                     | 104    |
| Uncorrect                                        | table Error Mask                       | 10     |
| Uncorrect                                        | table Error Severity                   | 10     |
| Correct                                          | table Error Status                     | 11     |
| Correct                                          | table Error Mask                       | 11     |
| Advanced Error                                   | r Capabilities and Control             | 11     |
|                                                  |                                        | 11     |
| L                                                | Header Log                             | 12     |
| '                                                | leader Log                             | 12     |
|                                                  |                                        | 12     |
| Root Error Co                                    | mmand (RC mode only)                   | 12     |
| Root Error S                                     | status (RC mode only)                  | 13     |
| Error Source ID                                  | Correctable Error Source ID            | 13     |
|                                                  |                                        | 13     |
|                                                  |                                        | 3F     |
|                                                  |                                        | 40     |
| PCI Express                                      | Controller Internal CSRs*              |        |
| . 3. 2xp.000                                     |                                        |        |
|                                                  |                                        | 6F     |
|                                                  |                                        | 70     |
|                                                  |                                        |        |
|                                                  |                                        |        |
|                                                  |                                        | F      |

<sup>\*</sup>Note that the PCI Express Controller Internal CSRs are not accessible by inbound PCI Express configuration transactions. Attempts to access these registers returns all 0s.

Figure 14-245. PCI Express extended configuration space

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 14.11.1 PCI Express Advanced Error Reporting Capability ID Register (Advanced\_Error\_Reporting\_Capability\_ID\_Register)



## Advanced\_Error\_Reporting\_Capability\_ID\_Register field descriptions

| Field                 | Description                                  |
|-----------------------|----------------------------------------------|
| 15–0<br>Capability_ID | Advanced error reporting capability = 0x0001 |

# 14.11.2 PCI Express Uncorrectable Error Status Register (Uncorrectable\_Error\_Status\_Register)



# Uncorrectable\_Error\_Status\_Register field descriptions

| Field       | Description                                                                                                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–21<br>-  | This field is reserved. Reserved                                                                                                                                                                                          |
| 20<br>URE   | Unsupported request error status.                                                                                                                                                                                         |
| 19<br>ECRCE | ECRC error status.                                                                                                                                                                                                        |
| 18<br>MTLP  | Malformed TLP status.                                                                                                                                                                                                     |
| 17<br>RXO   | Receiver overflow status.                                                                                                                                                                                                 |
| 16<br>UC    | Unexpected completion status.                                                                                                                                                                                             |
| 15<br>CA    | Completer abort status.                                                                                                                                                                                                   |
| 14<br>CTO   | Completion timeout status. Note that a completion timeout error is a fatal error. If a completion timeout error is detected, the system has become unstable. Hot reset is recommended to restore stability of the system. |
| 13<br>FCPE  | Flow control protocol error status.                                                                                                                                                                                       |
| 12<br>PTLP  | Poisoned TLP status.                                                                                                                                                                                                      |
| 11–5<br>-   | This field is reserved. Reserved                                                                                                                                                                                          |
| 4<br>DLPE   | Data link protocol error status.                                                                                                                                                                                          |
| 3–1<br>-    | This field is reserved. Reserved                                                                                                                                                                                          |
| 0<br>TE     | Training error status.                                                                                                                                                                                                    |

# 14.11.3 PCI Express Uncorrectable Error Mask Register (Uncorrectable\_Error\_Mask\_Register)



## Uncorrectable\_Error\_Mask\_Register field descriptions

| Field        | Description                      |
|--------------|----------------------------------|
| 31–21<br>-   | This field is reserved. Reserved |
| 20<br>UREM   | Unsupported request error mask   |
| 19<br>ECRCEM | ECRC error mask                  |
| 18<br>MTLPM  | Malformed TLP mask               |
| 17<br>RXOM   | Receiver overflow mask           |
| 16<br>UCM    | Unexpected completion mask       |
| 15<br>CAM    | Completer abort mask             |
| 14<br>CTOM   | Completion timeout mask          |
| 13<br>FCPEM  | Flow control protocol error mask |
| 12<br>PTLPM  | Poisoned TLP mask                |
| 11–5<br>-    | This field is reserved. Reserved |
| 4<br>DLPEM   | Data link protocol error mask    |

## **Uncorrectable\_Error\_Mask\_Register field descriptions (continued)**

| Field    | Description                      |
|----------|----------------------------------|
| 1        | This field is reserved. Reserved |
| 0<br>TEM | Training error mask              |

# 14.11.4 PCI Express Uncorrectable Error Severity Register (Uncorrectable\_Error\_Severity\_Register)





### Uncorrectable\_Error\_Severity\_Register field descriptions

| Field        | Description                        |
|--------------|------------------------------------|
| 31–21<br>-   | This field is reserved. Reserved   |
| 20<br>URES   | Unsupported request error severity |
| 19<br>ECRCES | ECRC error severity                |
| 18<br>MTLPS  | Malformed TLP severity             |
| 17<br>RXOS   | Receiver overflow severity         |
| 16<br>UCS    | Unexpected completion severity     |
| 15<br>CAS    | Completer abort severity           |
| 14<br>CTOS   | Completion timeout severity        |

### PCI Express extended configuration space

## **Uncorrectable\_Error\_Severity\_Register field descriptions (continued)**

| Field       | Description                          |
|-------------|--------------------------------------|
| 13<br>FCPES | Flow control protocol error severity |
| 12<br>PTLPS | Poisoned TLP severity                |
| 11–5<br>-   | This field is reserved. Reserved     |
| 4<br>DLPES  | Data link protocol error severity    |
| 3–0<br>-    | This field is reserved. Reserved     |

# 14.11.5 PCI Express Correctable Error Status Register (Correctable\_Error\_Status\_Register)





## Correctable\_Error\_Status\_Register field descriptions

| Field | Description             |
|-------|-------------------------|
| 31–14 | This field is reserved. |
| -     | Reserved                |

## Correctable\_Error\_Status\_Register field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13<br>ADVNFE | Advisory Non-Fatal Error Status indicates the occurrence of the advisory error, and the Advisory Non-Fatal Error Mask bit in the Correctable Error Mask register is checked to determine whether to proceed further with logging and signaling |
| 12<br>RTTO   | Replay timer timeout status                                                                                                                                                                                                                    |
| 11–9<br>-    | This field is reserved. Reserved                                                                                                                                                                                                               |
| 8<br>RNR     | REPLAY_NUM Rollover status                                                                                                                                                                                                                     |
| 7<br>BDLLP   | Bad DLLP status                                                                                                                                                                                                                                |
| 6<br>BTLP    | Bad TLP status                                                                                                                                                                                                                                 |
| 5–1<br>-     | This field is reserved. Reserved                                                                                                                                                                                                               |
| 0<br>RXE     | Receiver error status                                                                                                                                                                                                                          |

# 14.11.6 PCI Express Correctable Error Mask Register (Correctable\_Error\_Mask\_Register)





## Correctable\_Error\_Mask\_Register field descriptions

| Field      | Description                                                                                                                                           |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–14<br>- | This field is reserved. Reserved                                                                                                                      |
|            | Advisory Non-Fatal Error Mask – This bit is Set by default to enable compatibility with software that does not comprehend Role-Based Error Reporting. |

Table continues on the next page...

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## PCI Express extended configuration space

# Correctable\_Error\_Mask\_Register field descriptions (continued)

| Field       | Description                      |
|-------------|----------------------------------|
| 12<br>RTTOM | Replay timer timeout mask        |
| 11–9<br>-   | This field is reserved. Reserved |
| 8<br>RNRM   | REPLAY_NUM Rollover mask         |
| 7<br>BDLLPM | Bad DLLP mask                    |
| 6<br>BTLPM  | Bad TLP mask                     |
| 5–1<br>-    | This field is reserved. Reserved |
| 0<br>RXEM   | Receiver error mask              |

# 14.11.7 PCI Express Advanced Error Capabilities and Control Register (Advanced\_Error\_Capabilities\_and\_Control\_Register)



## Advanced\_Error\_Capabilities\_and\_Control\_Register field descriptions

| Field                          | Description                                                                                                                                                                                                                                       |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–9<br>-                      | This field is reserved. Reserved                                                                                                                                                                                                                  |
| 8<br>ECRCCE                    | ECRC checking enable                                                                                                                                                                                                                              |
| 7<br>ECRCCC                    | ECRC checking capable                                                                                                                                                                                                                             |
| 6<br>ECRCGE                    | ECRC generation enable                                                                                                                                                                                                                            |
| 5<br>ECRCGC                    | ECRC generation capable                                                                                                                                                                                                                           |
| 4–0<br>First_Error_<br>Pointer | The First Error Pointer is a read-only field that identifies the bit position of the first error reported in the uncorrectable error status register (see PCI Express Uncorrectable Error Status Register (Uncorrectable_Error_Status_Register)). |

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 14.11.8 PCI Express Header Log Register 1 (Header\_Log\_Register\_DWORD1)

The first DWORD of the PCI Express header log register is shown in the figure below.





### Header\_Log\_Register\_DWORD1 field descriptions

| Field           | Description                                         |
|-----------------|-----------------------------------------------------|
| 31–24<br>Byte_0 | Byte n of the TLP header associated with the error. |
| 23–16<br>Byte_1 | Byte n of the TLP header associated with the error. |
| 15–8<br>Byte_2  | Byte n of the TLP header associated with the error. |
| 7–0<br>Byte_3   | Byte n of the TLP header associated with the error. |

# 14.11.9 PCI Express Header Log Register 2 (Header\_Log\_Register\_DWORD2)

The second DWORD of the PCI Express header log register is shown in the figure below.

#### Address: 120h



### Header\_Log\_Register\_DWORD2 field descriptions

| Field           | Description                                         |
|-----------------|-----------------------------------------------------|
| 31–24<br>Byte_4 | Byte n of the TLP header associated with the error. |

## Header\_Log\_Register\_DWORD2 field descriptions (continued)

| Field           | Description                                         |
|-----------------|-----------------------------------------------------|
| 23–16<br>Byte_5 | Byte n of the TLP header associated with the error. |
| 15–8<br>Byte_6  | Byte n of the TLP header associated with the error. |
| 7–0<br>Byte_7   | Byte n of the TLP header associated with the error. |

# 14.11.10 PCI Express Header Log Register 3 (Header\_Log\_Register\_DWORD3)

The third DWORD of the PCI Express header log register is shown in the figure below.

### Address: 124h



### Header\_Log\_Register\_DWORD3 field descriptions

| Field           | Description                                         |
|-----------------|-----------------------------------------------------|
| 31–24<br>Byte_8 | Byte n of the TLP header associated with the error. |
| 23–16<br>Byte_9 | Byte n of the TLP header associated with the error. |
| 15–8<br>Byte_A  | Byte n of the TLP header associated with the error. |
| 7–0<br>Byte_B   | Byte n of the TLP header associated with the error. |

# 14.11.11 PCI Express Header Log Register 4 (Header\_Log\_Register\_DWORD4)

The fourth DWORD of the PCI Express header log register is shown in the figure below.

Address: 128h



## Header\_Log\_Register\_DWORD4 field descriptions

| Field           | Description                                         |
|-----------------|-----------------------------------------------------|
| 31–24<br>Byte_C | Byte n of the TLP header associated with the error. |
| 23–16<br>Byte_D | Byte n of the TLP header associated with the error. |
| 15–8<br>Byte_E  | Byte n of the TLP header associated with the error. |
| 7–0<br>Byte_F   | Byte n of the TLP header associated with the error. |

# 14.11.12 PCI Express Root Error Command Register (Root\_Error\_Command\_Register)

This register is supported only for RC mode.



## Root\_Error\_Command\_Register field descriptions

| Field      | Description                        |
|------------|------------------------------------|
| 31–3<br>-  | This field is reserved. Reserved   |
| 2<br>FERE  | Fatal error reporting enable.      |
| 1<br>NFERE | Non-fatal error reporting enable   |
| 0<br>CERE  | Correctable error reporting enable |

# 14.11.13 PCI Express Root Error Status Register (Root\_Error\_Status\_Register)

This register is supported only for RC mode.



Root\_Error\_Status\_Register field descriptions

| Field          | Description                              |
|----------------|------------------------------------------|
| 31–27<br>AEIMN | Advanced error interrupt message number. |
| 26–7<br>-      | This field is reserved. Reserved         |
| 6<br>FEMR      | Fatal error messages received.           |
| 5<br>NFEMR     | Non-fatal error messages received.       |
| 4<br>FUF       | First uncorrectable fatal.               |
| 3<br>MEFNFR    | Multiple ERR_FATAL/NONFATAL received.    |

## Root\_Error\_Status\_Register field descriptions (continued)

| Field      | Description                  |
|------------|------------------------------|
| 2<br>EFNFR | ERR_FATAL/NONFATAL received. |
| 1<br>MECR  | Multiple ERR_COR received.   |
| 0<br>ECR   | ERR_COR received.            |

# 14.11.14 PCI Express Correctable Error Source ID Register (Correctable\_Error\_Source\_ID\_Register)





## Correctable\_Error\_Source\_ID\_Register field descriptions

| Field | Description                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Loaded with the Requestor ID indicated in the received ERR_COR Message when the ERR_COR Received register is not already set. Default value of this field is 0. |

# 14.11.15 PCI Express Error Source ID Register (Error\_Source\_ID\_Register)

Address: 136h



### Error\_Source\_ID\_Register field descriptions

| Field           | Description                  |
|-----------------|------------------------------|
| 15–0            | ERR_FATAL/NONFATAL source ID |
| Error_Source_ID |                              |

# 14.11.16 LTSSM State Status Register (LTSSM\_State\_Status\_Register)

The PCI Express link training and status state machine (LTSSM) state status register provides detailed information about link training status. This register is useful for debugging link training failures.

### NOTE

The Status Code in PEX\_LTSSM\_STAT changes while reacting to the link status. Therefore, software may need to read PEX\_LTSSM\_STAT multiple times to ensure the value has stabilized.

The following table provides the encodings for the status code field of the PEX\_LTSSM\_STAT register.

Table 14-259. PEX\_LTSSM\_STAT Status Codes

| Status Code<br>(Hex) | LTSSM State Description             | Status Code<br>(Hex) | LTSSM State Description       |
|----------------------|-------------------------------------|----------------------|-------------------------------|
| 00                   | Detect quiet                        | 27                   | TX L0s FTS; RX L0s FTS        |
| 01                   | Detect active (0)                   | 28                   | L0 to L1 (0)                  |
| 02                   | Detect active (1)                   | 29                   | L0 to L1 (1)                  |
| 03                   | Detect active (2)                   | 2A                   | L1 entry                      |
| 04                   | Polling active (0)                  | 2B                   | L1 idle (0)                   |
| 05                   | Polling active (1)                  | 2C                   | L1 idle (1)                   |
| 06                   | Polling config (0)                  | 2D                   | L0 to L2 (0)                  |
| 07                   | Polling config (1)                  | 2E                   | L0 to L2 (1)                  |
| 08                   | Polling compliance                  | 2F                   | L2 entry                      |
| 09                   | Configuration link width start (0)  | 30                   | L2 idle (0)                   |
| 0A                   | Configuration link width start (1)  | 31                   | L2 idle (1)                   |
| 0B                   | Configuration link width accept (0) | 32                   | Recovery lock (0)             |
| 0C                   | Configuration link width accept (1) | 33                   | Recovery lock (1)             |
| 0D                   | Configuration lane number wait (0)  | 34                   | Recovery lock (2)             |
| 0E                   | Configuration lane number wait (1)  | 35                   | Recovery cfg (0)              |
| 0F                   | Configuration lane number wait (2)  | 36                   | Recovery cfg (1)              |
| 10                   | Configuration lane number wait (3)  | 37                   | Recovery idle (0)             |
| 11                   | Configuration lane number accept    | 38                   | Recovery idle (1)             |
| 12                   | Configuration complete (0)          | 39                   | Recovery to configuration     |
| 13                   | Configuration complete (1)          | ЗА                   | Recovery cfg to configuration |
| 14                   | Configuration idle (0)              | 3F                   | L0 no training                |

# Table 14-259. PEX\_LTSSM\_STAT Status Codes (continued)

| Status Code<br>(Hex) | LTSSM State Description                    | Status Code<br>(Hex) | LTSSM State Description             |
|----------------------|--------------------------------------------|----------------------|-------------------------------------|
| 15                   | Configuration idle (1)                     | 7F                   | Detect quiet El                     |
| 16                   | LO                                         | 49                   | Configuration link width start-RC   |
| 17                   | TX L0; RX L0s entry                        | 4A                   | Configuration link width accept-RC  |
| 18                   | TX L0; RX L0s idle                         | 4B                   | Configuration lane number wait-RC   |
| 19                   | TX L0; RX L0s fast training sequence (FTS) | 4C                   | Configuration lane number accept-RC |
| 1A                   | TX L0s entry (0); RX L0                    | 60                   | Loopback slave active (0)           |
| 1B                   | TX L0s entry (0); RX L0s idle              | 61                   | Loopback slave active (1)           |
| 1C                   | TX L0s entry (0); RX L0s FTS               | 62                   | Loopback slave exit                 |
| 1D                   | TX L0s entry (1); RX L0                    | 68                   | Hot reset (0)                       |
| 1E                   | TX L0s entry (1); RX L0s idle              | 69                   | Hot reset (1)                       |
| 1F                   | TX L0s entry (1); RX L0s FTS               | 6A                   | Hot reset (0)-RC                    |
| 20                   | TX L0s idle; RX L0                         | 6B                   | Hot reset (1)-RC                    |
| 21                   | TX L0s idle; RX L0s entry                  | 75                   | Disabled (0)                        |
| 22                   | TX L0s idle; RX L0s idle                   | 71                   | Disabled (1)                        |
| 23                   | TX L0s idle; RX L0s FTS                    | 72                   | Disabled (2)                        |
| 24                   | TX L0s FTS; RX L0                          | 73                   | Disabled (3)                        |
| 25                   | TX L0s FTS; RX L0s entry                   | 74                   | Disabled (4)                        |
| 26                   | TX L0s FTS; RX L0s idle                    | 78                   | L0 to L1/L2-RC                      |

### Address: 404h



# LTSSM\_State\_Status\_Register field descriptions

| Field              | Description                                  |
|--------------------|----------------------------------------------|
| 31–7<br>-          | This field is reserved. Reserved             |
| 6–0<br>Status_code | Status code. See Table 14-259 for encodings. |

# 14.11.17 PCI Express Controller Core Clock Ratio Register (Controller\_Core\_Clock\_Ratio\_Register)

### PCI Express extended configuration space

The PCI Express controller core clock ratio register is used to program the ratio of the actual PCI Express controller clock frequency to the default controller core frequency (which is half of the system bus frequency). This is required only when a PCI Express controller clock frequency other than the default value has to be used.

As an example of programming PEX\_GCLK\_RATIO, consider the case where the actual PCI Express controller clock is 200 MHz, the ratio of the actual clock to the default clock (267 MHz) is 3:4. that is, the default core clock has to be multiplied by the ratio (3/4, which is equivalent to 12/16). So the register has to be programmed with the decimal numerator value 12 or 0x0000\_000C.





### Controller\_Core\_Clock\_Ratio\_Register field descriptions

| Field                            | Description                                                                                                                                                                                                                                                                                |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–6<br>-                        | This field is reserved. Reserved                                                                                                                                                                                                                                                           |
| 5-0<br>Clock_Ratio_<br>Numerator | The numerator of the ratio of the actual PCI Express controller clock frequency used to the default core clock frequency of 267 MHz. The denominator of the ratio is fixed at 16.  The default value of this register is 0x10 (16 decimal), which corresponds to a ratio of 1:1 (or 16/16) |

# 14.11.18 PCI Express Power Management Timer Register (Power\_Management\_Timer\_Register)

The PCI Express power management timer register is used to program the time-in values for entering L1 power management states.

### Address: 450h



### **Power Management Timer Register field descriptions**

| Field | Description             |
|-------|-------------------------|
| 31–24 | This field is reserved. |
| -     | Reserved                |

### Power\_Management\_Timer\_Register field descriptions (continued)

| Field             | Description                                                                                                                                                           |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–12<br>L1_WAIT_ | Wait period (in PCI Express controller core clock cycles) before entering L1 power state after all functions are in a non-D0 power state. The value is calculated as: |
| PERIOD            | Time (in µsec) x PCI Express controller core clock frequency (in MHz)                                                                                                 |
|                   | The time value must be less than 2 $\mu$ sec; the default value ( 0x14D ) is 1 $\mu$ sec for the default clock frequency of 333 MHz .                                 |
| 11–0              | This field is reserved. Reserved                                                                                                                                      |

# 14.11.19 PCI Express PME Time-Out Register (PME\_Time\_Out\_Register)

This register is supported only for EP mode.

The PCI Express PME time-out register is used to program the time-out value that the controller uses before re-sending a PME message to the host. If PME is requested by a function and the host does not clear the associated PME\_STAT bit even after this time-out has expired, the PME message is sent again to the host by the PCI Express controller.

Address: 454h



## PME\_Time\_Out\_Register field descriptions

| Field               | Description                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>-          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                             |
| 25–0<br>PME_TIMEOUT | The PME time-out value specifies the interval before PME messages are resent by the controller, provided the PME_STAT bit in the PCI Express power management status and control register (offset 0x48) is not cleared by the host. The value for PME_TIMEOUT is specified in terms of PCI Express controller core clock cycles. The value is calculated as: |
|                     | Time (in µsec) x PCI Express controller core clock frequency (in MHz)                                                                                                                                                                                                                                                                                        |
|                     | The minimum time value is 100 msec; the default value (0x1FC1E20) is 100 msec for the default clock frequency of 333 MHz .                                                                                                                                                                                                                                   |

# 14.11.20 PCI Express Subsystem Vendor ID Update Register (Subsystem\_Vendor\_ID\_Update\_Register)

This register is supported only for EP mode.

### PCI Express extended configuration space

The PCI Express subsystem vendor ID update register is used to set the values for the Subsystem ID and Subsystem Vendor ID registers in the Type 0 configuration header.

When used as an endpoint, the controller's initialization software programs the desired subsystem ID and subsystem vendor ID values in PEX\_SSVID\_UPDATE before setting the CFG\_READY bit in the PEX\_CFG\_READY register (see Configuration Ready Register (Configuration\_Ready\_Register)). That way, when the host begins system enumeration, the correct values are present in the Type 0 configuration header.



| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |    | SS | ID |    |    |    |    |    |    |    |    |    |    |    |    |    |   | SSV | / ID |   |   |   |   |   | - |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     | _10  |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### Subsystem\_Vendor\_ID\_Update\_Register field descriptions

| Field          | Description                      |
|----------------|----------------------------------|
| 31–16<br>SS_ID | Subsystem ID [15-0] value        |
| 15–0<br>SSV_ID | Subsystem vendor ID [15-0] value |

# 14.11.21 Configuration Ready Register (Configuration\_Ready\_Register)

The PCI Express configuration ready register is used to indicate configuration complete status to the transaction layer. The transaction layer handles configuration requests from external hosts only after the CFG\_READY bit is set. All the configuration requests received from external hosts before the CFG\_READY bit is set are completed with configuration request retry status (CRS). The CFG\_READY bit in this register should be set after all relevant configuration registers have been programmed. This makes sure the external host reads the correct capability advertisements during enumeration.

Note that the state of PEX\_CFG\_READY[CFG\_READY] is dependent upon the POR configuration setting described in EP Boot mode and inbound configuration transactions.







<sup>\*</sup> Notes:

### Configuration\_Ready\_Register field descriptions

| Field          | Description                                                                                                                                                                                                                                    |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–1<br>-      | This field is reserved. Reserved                                                                                                                                                                                                               |
| 0<br>CFG_READY | Configuration ready  Note that the reset state of this bit is determined during POR.  1 The transaction layer accepts inbound configuration requests.  0 The transaction layer responds to all inbound configuration requests with retry (CRS) |

# 14.11.22 Flow Control Update Timeout Register (Flow\_Control\_Update\_Timeout\_Register)

The PCI Express flow control update timeout register is used to program the timeout value for update-FC DLLP reception in terms of PCI Express controller core clock cycles.





P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

<sup>•</sup> CFG\_READY field: Defined during POR. See description for details.

### Flow\_Control\_Update\_Timeout\_Register field descriptions

| Field                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31                            | Disable link retraining on FC update timeout error.                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| DIS_LR                        | The PCI Express protocol allows for optional link retraining by a device if FC updates are not received from the remote device within the timeout period programmed in bits [17-0] of this register. If the FC updates were lost due to link error issues, this retraining will help to restore normal operation. By default, this retraining is disabled. Since this is an optional feature, the user is allowed to enable or disable such automatic retraining, if desired. |  |  |
|                               | 1 Disable link retraining on FC update timeout error.                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                               | 0 Enable link retraining on FC update timeout error.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 30–18<br>-                    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 17-0<br>FC_UPDATE_<br>TIMEOUT | FC update timeout value specifies the interval (in PCI Express controller core clock cycles) to wait for the reception of consecutive FC-update DLLPs before indicating a flow-control protocol error. The value is calculated as:                                                                                                                                                                                                                                            |  |  |
|                               | Time (in µsec) x PCI Express controller core clock frequency (in MHz)                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                               | The maximum time value is 200 $\mu$ sec; the default value (0x10428) is 200 $\mu$ sec for the default clock frequency of 333 MHz .                                                                                                                                                                                                                                                                                                                                            |  |  |

# 14.11.23 Secondary Status Interrupt Mask Register (Secondary\_Status\_Interrupt\_Mask\_Register)

This register is supported only for RC mode.

The PCI Express secondary status interrupt mask register can be used to disable sideband interrupt generation when error bits in the PCI Express secondary status register are set. See PCI Express Secondary Status Register (Secondary\_Status\_Register), for more information. By default, interrupt generation due to secondary status errors is disabled.



### Secondary\_Status\_Interrupt\_Mask\_Register field descriptions

| Field       | Description                                                                                    |  |  |
|-------------|------------------------------------------------------------------------------------------------|--|--|
| 31–6<br>-   | This field is reserved. Reserved                                                               |  |  |
| 5<br>M_DPE  | Mask detected parity error. Default value is 1                                                 |  |  |
|             | <ul><li>1 Mask enabled (interrupt cannot be generated)</li><li>0 Mask disabled</li></ul>       |  |  |
| 4<br>M_SSE  | Mask signaled system error. Default value is 1                                                 |  |  |
|             | <ul><li>1 Mask enabled (interrupt cannot be generated)</li><li>0 Mask disabled</li></ul>       |  |  |
| 3<br>M_RMA  | Mask received master abort. Default value is 1  1 Mask enabled (interrupt cannot be generated) |  |  |
| 2<br>M_RTA  | 0 Mask disabled  Mask received target abort. Default value is 1                                |  |  |
|             | <ul><li>1 Mask enabled (interrupt cannot be generated)</li><li>0 Mask disabled</li></ul>       |  |  |
| 1<br>M_STA  | Mask signaled target abort. Default value is 1                                                 |  |  |
|             | <ul><li>1 Mask enabled (interrupt cannot be generated)</li><li>0 Mask disabled</li></ul>       |  |  |
| 0<br>M_MDPE | Mask master data parity error. Default value is 1                                              |  |  |
|             | <ul><li>1 Mask enabled (interrupt cannot be generated)</li><li>0 Mask disabled</li></ul>       |  |  |

# 14.12 Functional description

The PCI Express protocol relies on a requestor/completer relationship where one device requests that some desired action be performed by some target device and the target device completes the task and responds.

Usually the requests and responses occur through a network of links, but to the requestor and to the completer, the intermediate components are transparent.



Figure 14-269. Requestor/completer relationship

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### **Functional description**

Each PCI Express device is divided into two halves-transmit (TX) and receive (RX), and each of these halves is further divided into three layers-transaction, data link, and physical-as shown in Figure 14-270.



Figure 14-270. PCI Express high-level layering

Packets are formed in the transaction layer (TLPs) and data link layer (DLLPs), and each subsequent layer adds the necessary encodings and framing-as shown in Figure 14-271. As packets are received, they are decoded and processed by the same layers but in reverse order, so they may be processed by the layer or by the device application software.



Figure 14-271. PCI Express packet flow

## 14.12.1 Architecture

This section describes implementation details of the PCI Express controller.

# 14.12.1.1 PCI Express transactions

Table 14-267 contains the list of transactions that the PCI Express controller supports as an initiator and a target.

| PCI<br>Express<br>transactio<br>n | Supported<br>as an<br>Initiator | Supported as a target | Definition                                                                                                                                                                                                     |  |
|-----------------------------------|---------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mrd                               | Yes                             | Yes                   | Memory read request                                                                                                                                                                                            |  |
| MRdLk                             | No                              | No                    | Memory read lock. As a target, CplLk with UR status is returned.                                                                                                                                               |  |
| MWr                               | Yes                             | Yes                   | Memory write request to memory-mapped PCI-Express space                                                                                                                                                        |  |
| IORd                              | Yes (RC only)                   | No                    | I/O Read request. As a target, Cpl with UR status is returned.                                                                                                                                                 |  |
| IOWr                              | Yes (RC only)                   | No                    | I/O write request. As a target, Cpl with UR status is returned.                                                                                                                                                |  |
| CfgRd0                            | Yes (RC only                    | Yes                   | Configuration read type 0                                                                                                                                                                                      |  |
| CfgWr0                            | Yes (RC only)                   | Yes                   | Configuration write type 0                                                                                                                                                                                     |  |
| CfgRd1                            | Yes (RC only)                   | No                    | Configuration read type 1. As a target, Cpl with UR status is returned.                                                                                                                                        |  |
| CfgWr1                            | Yes (RC only)                   | No                    | Configuration write type 1. As a target, Cpl with UR status is returned.                                                                                                                                       |  |
| Msg                               | Yes                             | Yes                   | Message request                                                                                                                                                                                                |  |
| MsgD                              | Yes (RC only)                   | Yes (EP only)         | Message request with data payload. Note that Set_Slot_Power_Limit is the only message with data that is supported and then only when the controller is an initiator and in RC mode or a target and in EP mode. |  |
| Cpl                               | Yes                             | Yes                   | Completion without data                                                                                                                                                                                        |  |
| CpID                              | Yes                             | Yes                   | Completion with data                                                                                                                                                                                           |  |
| CplLk                             | No                              | Yes                   | Completion for locked memory read without data. The only time that CplLk is returned with UR status is when the controller receives a MRdLk command.                                                           |  |
| CpIDLk                            | No                              | No                    | Completion for locked memory read with data                                                                                                                                                                    |  |

Table 14-267. PCI Express transactions

# **14.12.1.2** Byte ordering

Whenever data cross a bridge between two busses, the byte ordering of data on the source and destination buses must be considered.

The internal platform bus of this device is inherently big endian and the PCI Express bus interface is inherently little endian.

There are two methods to handle ordering of data as it crosses a bridge-address invariance and data invariance. Address invariance preserves the addressing of bytes within a scalar data element, but not the relative significance of the bytes within that scalar. Conversely, data invariance preserves the relative significance of bytes within a scalar, but not the addressing of the individual bytes that make up a scalar.

This device uses address invariance as its byte ordering policy.

### 14.12.1.2.1 Address invariance

As stated above, address invariance preserves the byte address of each byte on an I/O interface as it is placed in memory or moved into a register.

This policy can have the effect of reversing the significance order of bytes (most significant to least significant and vice versa), but it has the benefit of preserving the format of general data structures. Provided that software is aware of the endianness and format of the data structure, it can correctly interpret the data on either side of the bridge.

The following figure shows the transfer of a 4-byte scalar, 0x4142\_4344, from a big endian source across an address invariant bridge to a little endian destination.



Figure 14-272. Address invariant byte ordering—4 bytes outbound

Note that although the significance of the bytes within the scalar have changed, the address of the individual bytes that make up the scalar have not changed. As long as software is aware that the source of the data used a big endian format, the data can be interpreted correctly.

The following figure shows data flowing the other way, from a little endian source to a big endian destination.



Figure 14-273. Address invariant byte ordering—4 bytes inbound

The following figure shows an outbound transfer of an 8-byte scalar, 0x5455\_1617\_CDCE\_2728, using address invariance.



Figure 14-274. Address invariant byte ordering—8 bytes outbound

The following figure shows an inbound transfer of a 2-byte scalar, 0x5837, using address invariance.



Figure 14-275. Address invariant byte ordering—2 bytes inbound

Note that in all of these examples, the original addresses of the individual bytes within the scalars (as created by the source) have been preserved.

# 14.12.1.2.2 Byte order for configuration transactions

All internal memory-mapped registers in the CCSR space use big endian byte ordering. However, the PCI Express specification defines PCI Express configuration registers as little endian.

All accesses to the PCI Express configuration port, PEX\_CONFIG\_DATA, including the those targeting the internal PCI Express configuration registers, use the address invariance policy as shown in Figure 14-276. Therefore, software must access PEX\_CONFIG\_DATA with little-endian formatted data-either using the lwbrx/stwbrx instructions or by manipulating the data before writing to and after reading from PEX\_CONFIG\_DATA.



Figure 14-276. PEX\_CONFIG\_DATA byte ordering

### 14.12.1.3 Lane reversal

The x4 PCI Express controller supports lane reversal. Table 14-268 describes the supported configurations.

Table 14-268. Lane assignment with and without lane reversal (x4 controller)

| Link configuration            | Lane 0 | Lane 1 | Lane 2 | Lane 3 |
|-------------------------------|--------|--------|--------|--------|
| x4 link without lane reversal | 0      | 1      | 2      | 3      |
| x2 link without lane reversal | 0      | 1      | -      | -      |
| x1 link without lane reversal | 0      | -      | -      | -      |
| x4 link with lane<br>reversal | 3      | 2      | 1      | 0      |

Table 14-268. Lane assignment with and without lane reversal (x4 controller) (continued)

| Link configuration            | Lane 0 | Lane 1 | Lane 2 | Lane 3 |
|-------------------------------|--------|--------|--------|--------|
| x2 link with lane<br>reversal | -      | -      | 1      | 0      |
| x1 link with lane<br>reversal | -      | -      | -      | 0      |

**NOTE:** The numbers shown in this table (0-3) are the lane numbers assigned to each lane as a result of link initialization and configuration. - indicates that the lane is not part of the configured link.

Note that lane reversal is only effective for devices that use the full link width supported by the controller (x4 lanes). That is, if a x1 device is connected to lane 0 and the link training fails without lane reversal, the lane reversal causes the link to attempt connection on lane 3 which would be impossible.

# 14.12.1.4 Transaction ordering rules

In general, transactions are serviced in the order that they are received.

However, transactions can be reordered as they are sent due to a stalled condition such as a full internal buffer. Table 14-269 describes the transaction ordering rules for this device.

Table 14-269. PCI Express controller TLP transaction ordering rules

| Row pass column?   |                                                        | Posted request                                | Non-posted request      |                                                     | Completion                                |                                                           |
|--------------------|--------------------------------------------------------|-----------------------------------------------|-------------------------|-----------------------------------------------------|-------------------------------------------|-----------------------------------------------------------|
|                    |                                                        | Memory write<br>or message<br>request (col 2) | Read request<br>(Col 3) | I/O or<br>Configuration<br>write request<br>(col 4) | Read<br>completion<br>(Col 5)             | I/O or<br>configuration<br>write<br>completion<br>(col 6) |
| Posted request     | Memory write or<br>message<br>request (row A)          | a) No <sup>1</sup><br>b) No <sup>1</sup>      | Yes                     | Yes                                                 | a) Yes²<br>b) N/A³                        | a) Yes <sup>2</sup><br>b) N/A <sup>3</sup>                |
| Non-posted request | Read request (row B)                                   | No                                            | No                      | No                                                  | a) No <sup>4</sup><br>b) Yes <sup>5</sup> | a) No <sup>4</sup><br>b)Yes <sup>5</sup>                  |
|                    | I/O or<br>configuration<br>write request<br>(Row C)    | No                                            | No                      | No                                                  | a) No <sup>4</sup><br>b) Yes <sup>5</sup> | a) No <sup>4</sup><br>b) Yes <sup>5</sup>                 |
| Completion         | Read completion (row D)                                | a) No <sup>6</sup><br>b) Yes <sup>7</sup>     | Yes                     | Yes                                                 | a) No <sup>8</sup><br>b) No <sup>8</sup>  | No                                                        |
|                    | I/O or<br>configuration<br>write completion<br>(row E) | a) No <sup>6</sup><br>b) Yes <sup>7</sup>     | Yes                     | Yes                                                 | No                                        | No                                                        |

### **Functional description**

- 1. Regardless of the setting of the relaxed ordering (RO) bit, a posted request cannot bypass another posted request.
- 2. Regardless of the setting of the relaxed ordering bit, a posted request can always bypass a completion.
- N/A indicates that the original rules at these entries defined by the PCI Express Base Specification do not apply to RC or EP.
- 4. A non-posted request cannot bypass a completion if the relaxed ordering bit is cleared (that is, RO = 0).
- 5. A non-posted request can bypass a completion if the relaxed ordering bit is set (that is, RO = 1).
- 6. A read completion, I/O write completion, or configuration write completion cannot bypass a posted request if the relaxed ordering bit is cleared (that is, RO = 0).
- 7. A read completion, I/O write completion, or configuration write completion can bypass a posted request if the relaxed ordering bit is set (that is, RO = 1).
- 8. Regardless of the setting of the relaxed ordering bit, a read completion cannot bypass another read completion.

In general, the following points summarize the ordering rules for sending the next outstanding request:

- A posted request can bypass all other transactions except another posted request.
- A non-posted request cannot bypass posted or other non-posted requests, but it can bypass a completion if the relaxed ordering (RO) bit is set.(See Table 14-269).
- A completion can bypass posted requests if the relaxed ordering (RO) bit is set and can bypass non-posted transactions. However, a completion cannot bypass other completions.

## 14.12.1.5 PCI Express outbound ATMUs

Outbound transactions should hit into one of the outbound ranges defined by the outbound ATMUs. The outbound address translation windows must be aligned based on the granularity selected by the size fields. Outbound window misses use the default outbound register set (outbound ATMU window 0).

Overlapping outbound windows (1-4) are not supported and will cause undefined behavior. Note that for RC mode, all outbound transactions post ATMU must hit either into the memory base/limit range or the prefetchable memory base/limit range defined in the PCI Express type 1 header. For EP mode, there is no such requirement.

Note that in RC mode, there is no checking on whether the translated address actually hits into the memory base/limit range. It will just pass it through as is.

Figure 14-277 shows the outbound transaction flow.



Figure 14-277. RC outbound transaction flow

# 14.12.1.6 PCI Express inbound ATMUs

There are differences between RC and EP implementations of the inbound ATMU registers as described in the following sections.

# 14.12.1.6.1 EP inbound ATMU implementation

All base address registers (BARs) reside in the PCI Express type 0 configuration header space which is accessible through the PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA mechanism.

Note that host software must program these BARs using configuration type 0 cycles. There are 4 inbound BARs.

- Inbound window BAR0, also known as PEXCSRBAR, at configuration address 0x10 (32-bit). This is a fixed 1-Mbyte window used for inbound memory transactions that access memory-mapped registers.
- Inbound window BAR1 at configuration address 0x14 (32-bit)
- Inbound window BAR2 at configuration address 0x18-0x1c (64-bit)
- Inbound window BAR3 at configuration address 0x20-0x24 (64-bit)

### **Functional description**

The PCI Express controller does not implement a shadow of the inbound BARs in the memory-mapped register set. However, when there is a hit to the BAR(s), the PCI Express controller uses the corresponding translation and attribute registers in the memory-mapped register set (PEXITAR*n* and PEXIWAR*n*) for the translation. If the transaction hits multiple BARs, then the lowest-numbered BAR is used.

## 14.12.1.6.2 RC inbound ATMU implementation

In RC mode, inbound window BAR0/PEXCSRBAR is the only inbound BAR that resides in the PCI Express type 1 configuration header (at offset 0x10); the remaining inbound window BARs (PEXIWBAR[1-3]) reside outside of the type 1 header in the memory-mapped register space.

If the transaction hits any window, the translation is performed and then the transaction is sent to memory. If there is no hit to any one of the BARs, then an UR completion is returned for non-posted transactions. All posted transactions with no BAR hit are ignored.

Figure 14-278 shows the inbound transaction flow in RC mode.



Figure 14-278. RC inbound transaction flow

## 14.12.1.7 Memory space addressing

A PCI Express memory transaction can address a 32- or 64-bit memory space.

The FMT[0] field in the PCI Express TLP header for a 32-bit address packet is 0; a 64-bit address packet has a FMT[0] = 1. The PCI Express TLP header for a memory read transaction has TYPE[4:0] = 00000 and FMT[1] = 0. A memory write transaction has TYPE[4:0] = 00000 and FMT[1] = 1. As an initiator, the controller is capable of sending 32- or 64-bit memory packets. Any transaction from the internal platform that (after passing through the translation mechanism) has a translated address greater than 4G is sent as a 64-bit memory packet. Otherwise, a 32-bit memory packet is sent. As a target device, the controller is capable of decoding 32- or 64-bit memory packets. This is done through two 32-bit inbound windows and two 64-bit inbound windows. All inbound addresses are translated to 36-bit internal platform addresses.

## 14.12.1.8 I/O space addressing

The controller does not support I/O transactions as a target. As an initiator, the controller can send I/O transactions in RC mode only.

This can be done by programming one of the outbound translation window's attribute to send I/O transactions. All I/O transactions only access 32-bit address I/O space. The PCI Express TLP header for an I/O read transaction has TYPE[4:0] = 00010 and FMT[1] = 0. The PCI Express TLP header for an I/O write transaction has TYPE[4:0] = 00010 and FMT[1] = 1.

# 14.12.1.9 Configuration space addressing

As an initiator, the controller supports both type 0 and type 1 configuration cycles when configured in RC mode. There are two methods of generating a configuration transaction; refer to PCI Express configuration space access, for more information.

A configuration transaction can hit into the controller's internal configuration space, it can be sent out on the PCI Express link, or it can be internally terminated.

All configuration transactions sent on PCI Express require a response regardless whether they are read or a write configuration transactions. Table 14-270 shows PCI Express TLP header configuration.

| Table 14-270. | PCI Express TLP header configuration |
|---------------|--------------------------------------|
|               |                                      |

| TLP header type | Configuration read transaction   | Configuration write transaction  |
|-----------------|----------------------------------|----------------------------------|
| Type 0          | TYPE[4:0]= 00100 and FMT[1] = 0  | TYPE[4:0] = 00100 and FMT[1] = 1 |
| Type 1          | TYPE[4:0] = 00101 and FMT[1] = 0 | TYPE[4:0] = 00101 and FMT[1] = 1 |

### **Functional description**

The controller does not generate configuration transactions in EP mode. Only inbound configuration transactions are supported in EP mode.

# 14.12.1.10 PCI Express configuration space access

PCI Express configuration space access depends on whether the device is in RC or EP mode, as described in the following sections.

## 14.12.1.10.1 RC configuration register access

In RC mode, there are two methods for accessing the external PCI Express configuration space:

- PCI Express configuration access registers (PEX\_CONFIG\_ADDR/ PEX\_CONFIG\_DATA)
- PCI Express outbound ATMU window

To access internal configuration space, software must rely on the PCI Express configuration access register (PEX\_CONFIG\_ADDR/ PEX\_CONFIG\_DATA) mechanism. To access external configuration space, software can either use configuration access registers or the outbound ATMU mechanism. For the configuration access register method, a value must be written to the PEX\_CONFIG\_ADDR register that specifies the targeted PCI Express bus, the targeted device on that bus, the targeted function within the device, and the configuration register in that device that should be accessed. The PCI Express controller's bus number is obtained from the PCI Express configuration header (type 1). Then either a write or a read to the PEX\_CONFIG\_DATA register triggers the actual write or read cycle to the configuration space.

### NOTE

Accesses to the little-endian PCI Express configuration space must be properly formatted. See Byte order for configuration transactions, for more information.

External configuration transactions should not be attempted until the link has successfully trained. Software can poll the LTSSM state status register (PEX\_LTSSM\_STAT) to check the status of link training before issuing external configuration requests.

Refer to Configuration accesses and inbound writes to CCSR space, for special considerations regarding outbound configuration accesses and inbound writes to CCSR space.

#### 14.12.1.10.1.1 PCI Express configuration access register mechanism

There are two types of configuration transactions (Type 0 and Type 1) needed to support hierarchical bridges.

- If the targeted bus number, and targeted device number equal to the PCI Express controller's bus number and device number, and the targeted function number is zero, then an internal PCI Express configuration cycle access is performed.
- If the targeted bus number does not equal the PCI Express controller's bus number, but does equal the secondary bus number (from the type 1 header) and the targeted device number is 0, then a Type 0 configuration transaction is sent to the PCI Express link.
- If the targeted bus number does not equal the PCI Express controller's bus number, and does not equal the secondary bus number (from the type 1 header), and the targeted bus number is less than or equal to the subordinate bus number (from the type 1 header), then a Type 1 configuration transaction is sent to the PCI Express link.
- If none of the above conditions occur, then the PCI Express controller returns all 1s for reads and ignores writes. In this case, PEX\_ERR\_DR[ICCA] is set.

#### 14.12.1.10.1.2 Outbound ATMU configuration mechanism (RC-only)

Software can also program one of the outbound ATMU windows to perform a configuration access. This is accomplished by programming the ReadTType or WriteTType field of the desired PEXOWAR to 0x2. Software must only issue 4-byte or less access to the ATMU configuration window and the access cannot cross a 4-byte boundary. The targeted bus number, targeted device number, targeted function number, register, and targeted extended register number sent are decoded from the outbound translated PCI Express address.

- targeted bus number[7:0] = PCI Express address[27:20]
- targeted device number[4:0] = PCI Express address[19:15]
- targeted function number[2:0] = PCI Express address[14:12]
- targeted extended register number[3:0] = PCI Express address[11:8]
- targeted register number[5:0] = PCI Express address[7:2]

A Type 0 configuration cycle is sent to the link if the targeted bus number equals the secondary bus number (from the type 1 header) and targeted device number is 0. A Type 1 configuration cycle is sent to the link if targeted bus number does not equal primary bus and secondary bus numbers and it is less than or equal to the subordinate bus number

#### **Functional description**

(from the type 1 header). For all other cases, the PCI Express controller squashes the write and read results in a response with error returned. In this case, PEX\_ERR\_DR[IACA] is set.

Note that the PCI Express controller does not support access to its internal configuration registers using the outbound ATMU mechanism. That is, the outbound ATMU mechanism must not be used to program the internal registers.

#### 14.12.1.10.2 EP configuration register access

When the PCI Express controller is configured as an EP device it responds to remote host generated configuration cycles.

This is indicated by decoding the configuration command along with type 0 access in the packet. A remote host can access all of the PCI Express configuration area except the PCI Express controller internal CSR registers in the extended PCI Express configuration space at offsets 0x400-0x6FF. The PCI Express controller internal CSR registers are not accessible by inbound PCI Express configuration transactions. Attempts to access these registers return all zeros.

While in EP mode, the PCI Express controller does not support generating configuration accesses as a master. All accesses to PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA cause the device to access the internal configuration registers regardless of the targeted bus number or targeted device number programmed in the PEX\_CONFIG\_ADDR register. There is no configuration mechanism supported in EP mode using the ATMU window. If the outbound ATMU window is configured to issue a configuration transaction, all posted transactions hitting this window are ignored and all non-posted transactions get a response with an error.

#### 14.12.1.11 Serialization of configuration and I/O writes

Configuration and I/O writes are serialized by the controller.

The logic after issuing a configuration write or IO write does not issue any new transactions until the outstanding configuration or I/O write is finished. This means that an acknowledgement packet from the link partner in the form of a CpL TLP packet must be seen or the transaction has timed out. If the CpL packet contains a CRS status, then the logic re-issues the configuration write transaction. It keeps retrying the request until either a status other than CRS is returned or the transaction times out.

Note that it is possible for outbound configuration read request to be requeued and be placed at the end of the request queue due to CRS condition.

#### 14.12.1.12 Messages

Software message generation is supported in both RC and EP modes.

#### 14.12.1.12.1 Outbound ATMU message generation

Software can choose to send a message by programming PEXOWARn[WTT] = 0x5.

A message is sent by writing a 4-byte transaction in big-endian format that hits in an outbound window configured to send messages.

Part of the 4-byte data is used to store information such as message code and routing information. Table 14-271 describes the message data format.

| Bits  | Name    | Reset value | Description                                                   |
|-------|---------|-------------|---------------------------------------------------------------|
| 0-15  | -       | -           | Reserved                                                      |
| 16-18 | Routing | x           | Routing mechanism. Contains the message's routing information |
| 19-23 | -       | -           | Reserved                                                      |
| 24-31 | Code    | x           | Message code. Contains the actual message type to be sent.    |

Table 14-271. Internal platform Message data format

In addition to the outbound ATMU, the PEX PM Command register also provides the capability to send PME\_Turn\_Off message or PM\_PME message by setting bits 31 or 29. See PCI Express power management command register (PEX\_PEX\_PMCR) for more information.

Table 14-272 provides a complete list of supported outbound messages depending on whether RC or EP is configured.

Name Code[7:0] Routing[2:0] **RC** EP Description Assert INTA 0010 0000 100 N/A Yes Sent upstream by endpoint 100 N/A Yes Assert\_INTB 0010 0001 Sent upstream by endpoint N/A Yes Assert\_INTC 0010 0010 100 Sent upstream by endpoint N/A Yes Assert\_INTD 0010 0011 100 Sent upstream by endpoint N/A Yes Deassert\_INTA 0010 0100 100 Sent upstream by endpoint Yes Deassert INTB 100 N/A 0010 0101 Sent upstream by endpoint Deassert INTC 0010 0110 100 N/A Yes Sent upstream by endpoint 100 N/A Yes Deassert\_INTD 0010 0111 Sent upstream by endpoint PM\_Active\_State\_Nak 0001 0100 100 Yes N/A Terminate at receiver

Table 14-272. PCI Express ATMU outbound messages

Table 14-272. PCI Express ATMU outbound messages (continued)

| Name                      | Code[7:0] | Routing[2:0] | RC  | EP  | Description                                                            |
|---------------------------|-----------|--------------|-----|-----|------------------------------------------------------------------------|
| PM_PME                    | 0001 1000 | 000          | N/A | Yes | Sent upstream by PME-requesting component                              |
| PME_Turn_Off              | 0001 1001 | 011          | Yes | N/A | Broadcast downstream                                                   |
| PM_TO_Ack                 | 0001 1011 | 101          | N/A | Yes | Sent upstream by endpoint                                              |
| ERR_COR                   | 0011 0000 | 000          | N/A | Yes | Sent by component when it detects a correctable error                  |
| ERR_NONFATAL              | 0011 0001 | 000          | N/A | Yes | Sent by component when it detects a Non-<br>fatal, uncorrectable error |
| ERR_FATAL                 | 0011 0011 | 000          | N/A | Yes | Sent by component when it detects a Fatal, uncorrectable error         |
| Unlock                    | 0000 0000 | 000          | No  | N/A | Not supported                                                          |
| Set_Slot_Power_Limit      | 0101 0000 | 100          | Yes | N/A | Set slot power limit in upstream port                                  |
| Vendor_Defined Type 0     | 0111 1110 |              | No  | No  | Not supported                                                          |
| Vendor_Defined Type 1     | 0111 1111 |              | No  | No  | Not supported                                                          |
| Attention_Indicator_On    | 0100 0001 | 100          | Yes | N/A | Hot-plug message                                                       |
| Attention_Indicator_Blink | 0100 0011 | 100          | Yes | N/A | Hot-plug message                                                       |
| Attention_Indicator_Off   | 0100 0000 | 100          | Yes | N/A | Hot-plug message                                                       |
| Power_Indicator_On        | 0100 0101 | 100          | Yes | N/A | Hot-plug message                                                       |
| Power_Indicator_Blink     | 0100 0111 | 100          | Yes | N/A | Hot-plug message                                                       |
| Power_Indicator_Off       | 0100 0100 | 100          | Yes | N/A | Hot-plug message                                                       |
| Attention_Button_Pressed  | 0100 1000 | 100          | N/A | Yes | Hot-plug message                                                       |

#### 14.12.1.12.2 Inbound messages

Table 14-273 provides a complete list of supported inbound messages in RC mode.

Table 14-273. PCI Express RC inbound message handling

| Name                | Code[7:0] | Routing[2:<br>0] | Action                               |
|---------------------|-----------|------------------|--------------------------------------|
| Assert_INTA         | 0010 0000 | 100              | Send to PIC                          |
| Assert_INTB         | 0010 0001 | 100              | Send to PIC                          |
| Assert_INTC         | 0010 0010 | 100              | Send to PIC                          |
| Assert_INTD         | 0010 0011 | 100              | Send to PIC                          |
| De-assert_INTA      | 0010 0100 | 100              | Send to PIC                          |
| De-assert_INTB      | 0010 0101 | 100              | Send to PIC                          |
| De-assert_INTC      | 0010 0110 | 100              | Send to PIC                          |
| De-assert_INTD      | 0010 0111 | 100              | Send to PIC                          |
| PM_Active_State_Nak | 0001 0100 | 100              | No action taken                      |
| PM_PME              | 0001 1000 | 000              | Generate interrupt to PIC if enabled |
| PME_Turn_Off        | 0001 1001 | 011              | No action taken                      |

Table 14-273. PCI Express RC inbound message handling (continued)

| Name                      | Code[7:0] | Routing[2:<br>0] | Action                                                                 |
|---------------------------|-----------|------------------|------------------------------------------------------------------------|
| PME_TO_Ack                | 0001 1011 | 101              | Set PEX_PME_MES_DR[ENL23] bit and generate interrupt to PIC if enabled |
| ERR_COR                   | 0011 0000 | 000              | Generate interrupt to PIC if enabled                                   |
| ERR_NONFATAL              | 0011 0001 | 000              | Generate interrupt to PIC if enabled                                   |
| ERR_FATAL                 | 0011 0011 | 000              | Generate interrupt to PIC if enabled                                   |
| Unlock                    | 0000 0000 | 000              | No action taken                                                        |
| Set_Slot_Power_Limit      | 0101 0000 | 100              | No action taken                                                        |
| Vendor_Defined Type 0     | 0111 1110 |                  | No action taken                                                        |
| Vendor_Defined Type 1     | 0111 1111 |                  | No action taken                                                        |
| Attention_Indicator_On    | 0100 0001 | 100              | No action taken                                                        |
| Attention_Indicator_Blink | 0100 0011 | 100              | No action taken                                                        |
| Attention_Indicator_Off   | 0100 0000 | 100              | No action taken                                                        |
| Power_Indicator_On        | 0100 0101 | 100              | No action taken                                                        |
| Power_Indicator_Blink     | 0100 0111 | 100              | No action taken                                                        |
| Power_Indicator_Off       | 0100 0100 | 100              | No action taken                                                        |
| Attention_Button_Pressed  | 0100 1000 | 100              | Set PEX_PME_MES_DR[ABP] bit and send interrupt if enabled.             |

Table 14-274 provides a complete list of supported inbound messages in EP mode.

Table 14-274. PCI Express EP inbound message handling

| Name                | Code[7:0] | Routing[2:0] | Action                                                  |
|---------------------|-----------|--------------|---------------------------------------------------------|
| Assert_INTA         | 0010 0000 | 100          | No action taken                                         |
| Assert_INTB         | 0010 0001 | 100          | No action taken                                         |
| Assert_INTC         | 0010 0010 | 100          | No action taken                                         |
| Assert_INTD         | 0010 0011 | 100          | No action taken                                         |
| Deassert_INTA       | 0010 0100 | 100          | No action taken                                         |
| Deassert_INTB       | 0010 0101 | 100          | No action taken                                         |
| Deassert_INTC       | 0010 0110 | 100          | No action taken                                         |
| Deassert_INTD       | 0010 0111 | 100          | No action taken                                         |
| PM_Active_State_Nak | 0001 0100 | 100          | No action taken                                         |
| PM_PME              | 0001 1000 | 000          | No action taken                                         |
| PME_Turn_Off        | 0001 1001 | 011          | Set PEX_PME_MES_DR[PTO] bit. Send interrupt if enabled. |
| PM_TO_Ack           | 0001 1011 | 101          | No action taken                                         |
| ERR_COR             | 0011 0000 | 000          | No action taken                                         |
| ERR_NONFATAL        | 0011 0001 | 000          | No action taken                                         |
| ERR_FATAL           | 0011 0011 | 000          | No action taken                                         |
| Unlock              | 0000 0000 | 000          | No action taken                                         |

| Table 14-274. | PCI Express EP | ণ inbound messa( | ge handling | (continued) |
|---------------|----------------|------------------|-------------|-------------|
|               |                |                  |             |             |

| Name                      | Code[7:0] | Routing[2:0] | Action                                                                               |
|---------------------------|-----------|--------------|--------------------------------------------------------------------------------------|
| Set_Slot_Power_Limit      | 0101 0000 | 100          | Update power value in PCI Express device capability register in configuration space. |
| Vendor_Defined Type 0     | 0111 1110 |              | No action taken                                                                      |
| Vendor_Defined Type 1     | 0111 1111 |              | No action taken                                                                      |
| Attention_Indicator_On    | 0100 0001 | 100          | Set PEX_PME_MES_DR[AION] bit. Send interrupt if enabled.                             |
| Attention_Indicator_Blink | 0100 0011 | 100          | Set PEX_PME_MES_DR[AIB] bit. Send interrupt if enabled.                              |
| Attention_Indicator_Off   | 0100 0000 | 100          | Set PEX_PME_MES_DR[AIOF] bit. Send interrupt if enabled.                             |
| Power_Indicator_On        | 0100 0101 | 100          | Set PEX_PME_MES_DR[PION] bit. Send interrupt if enabled.                             |
| Power_Indicator_Blink     | 0100 0111 | 100          | Set PEX_PME_MES_DR[PIB] bit. Send interrupt if enabled.                              |
| Power_Indicator_Off       | 0100 0100 | 100          | Set PEX_PME_MES_DR[PIOF] bit. Send interrupt if enabled.                             |
| Attention_Button_Pressed  | 0100 1000 | 100          | No action taken                                                                      |

## **14.12.1.13** Error handling

The PCI Express specification classifies errors as correctable and uncorrectable.

Correctable errors result in degraded performance, but uncorrectable errors generally result in functional failures. As shown in Figure 14-279 uncorrectable errors can further be classified as fatal or non-fatal.



Figure 14-279. PCI Express error classification

#### 14.12.1.13.1 PCI Express error logging and signaling

Figure 14-280 shows the PCI Express-defined sequence of operations related to signaling and logging of errors detected by a device.

Note that the PCI Express controller on this device supports the advanced error handling capabilities shown within the dotted lines.



Figure 14-280. PCI Express device error signaling flowchart

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### 14.12.1.13.2 PCI Express controller internal interrupt sources

Table 14-275 describes the sources of the PCI Express controller internal interrupt to the PIC and the preconditions for signaling the interrupt.

Table 14-275. PCI Express internal controller interrupt sources

| Status register bit                                                                                                                                                                                                                      | Preconditions                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Any bit in PEX_PME_MES_DR set                                                                                                                                                                                                            | The corresponding interrupt enable bits must be set in PEX_PME_MES_IER                                                                                                                                                        |
| Any bit in PEX_ERR_DR set                                                                                                                                                                                                                | The corresponding interrupt enable bits must be set in PEX_ERR_EN.                                                                                                                                                            |
| PCI Express Root Status Register[16] (PME status) is set                                                                                                                                                                                 | PCI Express Root Control Register [3] (PME interrupt enable) is set                                                                                                                                                           |
| PCI Express Root Error Status Register[6] (fatal error messages received) is set                                                                                                                                                         | PCI Express Root Error Command Register [2] (fatal error reporting enable) is set                                                                                                                                             |
|                                                                                                                                                                                                                                          | or                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                          | PCI Express Root Control Register [2] (system error on fatal error enable) is set                                                                                                                                             |
| PCI Express Root Error Status Register [5] (non-fatal error messages received) is set                                                                                                                                                    | PCI Express Root Error Command Register [1] (non-fatal error reporting enable) is set                                                                                                                                         |
|                                                                                                                                                                                                                                          | or                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                          | PCI Express Root Control Register [1] (system error on non-fatal error enable) is set                                                                                                                                         |
| PCI Express Root Error Status Register[0] (correctable error messages received) is set                                                                                                                                                   | PCI Express Root Error Command Register[0] (correctable error reporting enable) is set                                                                                                                                        |
|                                                                                                                                                                                                                                          | or                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                          | PCI Express Root Control Register[0] (system error on correctable error enable) is set.                                                                                                                                       |
| Any correctable error status bit in PCI Express<br>Correctable Error Status Register is set                                                                                                                                              | The corresponding error mask bit in PCI Express Correctable Error Mask Register is clear and PCI Express Root Error Command Register[0] (correctable error reporting enable) is set                                           |
| Any fatal uncorrectable error status bit in PCI Express Uncorrectable Error Status Register is set. (The corresponding error is classified as fatal based on the severity setting in PCI Express Uncorrectable Error Severity Register.) | The corresponding error mask bit in PCI Express Uncorrectable Error Mask Register is clear and either PCI Express Device Control Register[2] (fatal error reporting) is set or PCI Express Command Register[8] (SERR) is set. |
| Any non-fatal uncorrectable error status bit in PCI Express Uncorrectable Error Status Register is set. (The corresponding error is                                                                                                      | The corresponding error mask bit in PCI Express Uncorrectable Error Mask Register is clear                                                                                                                                    |
| classified as non-fatal based on the severity                                                                                                                                                                                            | and                                                                                                                                                                                                                           |
| setting in PCI Express Uncorrectable Error Severity Register.)                                                                                                                                                                           | either PCI Express Device Control Register[1] (non-fatal error reporting) is set or PCI Express Command Register[8] (SERR) is set.                                                                                            |
| PCI Express Secondary Status Register[8] (master data parity error) is set.                                                                                                                                                              | PCI Express Secondary Status Interrupt Mask Register[0] (mask master data parity error) is cleared and PCI Express Command Register[6] (parity error response) is set.                                                        |
| PCI Express Secondary Status Register[11] (signaled target abort) is set                                                                                                                                                                 | PCI Express Secondary Status Interrupt Mask Register[1] (mask signaled target abort) is cleared.                                                                                                                              |

## Table 14-275. PCI Express internal controller interrupt sources (continued)

| Status register bit                                                       | Preconditions                                                                                                                                |
|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| PCI Express Secondary Status Register[12] (received target abort) is set  | PCI Express Secondary Status Interrupt Mask Register[2] (mask received target abort) is cleared.                                             |
| PCI Express Secondary Status Register[13] (received master abort) is set  | PCI Express Secondary Status Interrupt Mask Register[3] (mask received master abort) is cleared.                                             |
| PCI Express Secondary Status Register[14] (signaled system error) is set. | PCI Express Secondary Status Interrupt Mask Register[4] (mask signaled system error) is cleared.                                             |
| PCI Express Secondary Status Register[15] (detected parity error) is set  | PCI Express Secondary Status Interrupt Mask Register[5] (mask detected parity error) is cleared.                                             |
| PCI Express Slot Status Register[0] (attention button pressed) is set     | PCI Express Slot Control Register[0] (attention button pressed enable) is set and                                                            |
|                                                                           | PCI Express Slot Control Register[5] (hot plug interrupt enable) is set and                                                                  |
|                                                                           | either PCI Express PM Control Register[1-0] = 00 (the function power state is D0) or PCI Express PM Control Register[8] (PME enable) is set. |
| PCI Express Slot Status Register[1] (power                                | PCI Express Slot Control Register[1] (power fault detected enable) is set                                                                    |
| fault detected) is set                                                    | and                                                                                                                                          |
|                                                                           | PCI Express Slot Control Register[5] (hot plug interrupt enable) is set                                                                      |
|                                                                           | and                                                                                                                                          |
|                                                                           | either PCI Express PM Control Register[1-0] = 00 (the function power state is D0) or PCI Express PM Control Register[8] (PME enable) is set. |
| PCI Express Slot Status Register[2] (MRL                                  | PCI Express Slot Control Register[2] (MRL sensor changed enable) is set                                                                      |
| sensor changed) is set                                                    | and                                                                                                                                          |
|                                                                           | PCI Express Slot Control Register[5] (hot plug interrupt enable) is set                                                                      |
|                                                                           | and                                                                                                                                          |
|                                                                           | either PCI Express PM Control Register[1-0] = 00 (the function power state is D0) or PCI Express PM Control Register[8] (PME enable) is set. |
| PCI Express Slot Status Register[3] (presence detect changed) is set      | PCI Express Slot Control Register[3] (presence detect changed enable) is set                                                                 |
|                                                                           | and                                                                                                                                          |
|                                                                           | PCI Express Slot Control Register[5] (hot plug interrupt enable) is set                                                                      |
|                                                                           | and                                                                                                                                          |
|                                                                           | either PCI Express PM Control Register[1-0] = 00 (the function power state is D0) or PCI Express PM Control Register[8] (PME enable) is set. |
| PCI Express Slot Status Register[4] (command completed) is set            | PCI Express Slot Control Register[4] (command completed interrupt enable) is set                                                             |
|                                                                           | and                                                                                                                                          |
|                                                                           | PCI Express Slot Control Register[5] (hot plug interrupt enable) is set.                                                                     |

#### 14.12.1.13.3 Error conditions

Table 14-276 describes specific error types and the action taken for various transaction types.

Table 14-276. Error conditions

| Transaction Type | Error Type                                                                                                                                                                                                                              | Action                                                                                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Inbound response | PEX response time out. This case happens when the internal platform sends a non-posted request that did not get a response back after a specific amount of time specified in the outbound completion timeout register (PEX_OTB_CPL_TOR) | Log error (PEX_ERR_DR[PCT]) and send interrupt to PIC, if enabled.                                                                                               |
| Inbound response | Unexpected PEX response. This can happen if, after the response times out and the internal queue entry is deallocated, the response comes back.                                                                                         | Log unexpected completion error (PCI Express Uncorrectable Status Register[16]) and send interrupt to PIC, if enabled.                                           |
| Inbound response | Unsupported request (UR) response status                                                                                                                                                                                                | Depending upon whether the initial internal request was broken up, the error is not sent until all responses come back for all portions of the internal request. |
|                  |                                                                                                                                                                                                                                         | Log the error (PEX_ERR_DR[CDNSC] and PCI Express Uncorrectable Status Register[20]) and send interrupt to PIC, if enabled.                                       |
| Inbound response | Completer abort (CA) response status                                                                                                                                                                                                    | Depending upon whether the initial internal request was broken up, the error is not sent until all responses come back for all portions of the internal request. |
|                  |                                                                                                                                                                                                                                         | Log the error (PEX_ERR_DR[PCAC, CDNSC] and PCI Express Uncorrectable Status Register[15] and send interrupt to PIC, if enabled.                                  |
| Inbound response | Poisoned TLP (EP=1)                                                                                                                                                                                                                     | Depending upon whether the initial internal request was broken up, the error is not sent until all responses come back for all portions of the internal request. |
|                  |                                                                                                                                                                                                                                         | Log the error (PCI Express Uncorrectable Status Register[12]) and send interrupt to PIC, if enabled.                                                             |
| Inbound response | ECRC error                                                                                                                                                                                                                              | Depending upon whether the initial internal request was broken up, the error is not sent until all responses come back for all portions of the internal request. |
|                  |                                                                                                                                                                                                                                         | Log the error (PCI Express Uncorrectable Status Register[19]) and send interrupt to PIC, if enabled.                                                             |

## Table 14-276. Error conditions (continued)

| Transaction Type | Error Type                                                                                                                            | Action                                                                                                                                                                                                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Inbound response | Configuration Request Retry Status (CRS) timeout for a configuration transaction that originates from PEX_CONFIG_ADDR/PEX_CONFIG_DATA | 1.The controller always retries the transaction as soon as possible until a status other than CRS is returned. However, if a CRS status is returned after the configuration retry timeout (PEXCONF_RTY_TOR) timer expires, then the controller aborts the transaction and sends all 1s (0xFFFF_FFFF) data back to requester. |
|                  |                                                                                                                                       | 2. Log the error (PEX_ERR_DR[PCT]) and send interrupt to the PIC, if enabled.                                                                                                                                                                                                                                                |
| Inbound response | UR response for configuration transaction that originates from PEX_CONFIG_ADDR/                                                       | 1. Send back all 1s (0xFFFF_FFFF) data.                                                                                                                                                                                                                                                                                      |
|                  | PEX_CONFIG_DATA                                                                                                                       | 2. Log the error (PEX_ERR_DR[CDNSC] and PCI Express Uncorrectable Status Register[20]) and send interrupt to PIC, if enabled.                                                                                                                                                                                                |
| Inbound response | CA response for Configuration transaction that                                                                                        | 1. Send back all 1s (0xFFFF_FFFF) data.                                                                                                                                                                                                                                                                                      |
|                  | originates from PEX_CONFIG_ADDR/ PEX_CONFIG_DATA                                                                                      | 2. Log the error (PEX_ERR_DR[PCAC, CDNSC] and PCI Express Uncorrectable Status Register[15]) and send interrupt to PIC, if enabled.                                                                                                                                                                                          |
| Inbound response |                                                                                                                                       | 1. Send back all 1s (0xFFFF_FFFF) data.                                                                                                                                                                                                                                                                                      |
|                  | transaction that originates from PEX_CONFIG_ADDR/ PEX_CONFIG_DATA                                                                     | 2. Log the error (PCI Express Uncorrectable Status Register[12]) and send interrupt to PIC, if enabled.                                                                                                                                                                                                                      |
| Inbound response | ECRC error response for Configuration                                                                                                 | 1. Send back all 1s (0xFFFF_FFFF) data.                                                                                                                                                                                                                                                                                      |
|                  | transaction that originates from PEX_CONFIG_ADDR/ PEX_CONFIG_DATA                                                                     | 2. Log the error (PCI Express Uncorrectable Status Register[19]) and send interrupt to PIC, if enabled.                                                                                                                                                                                                                      |
| Inbound response | Configuration Request Retry Status (CRS) response for Configuration transaction that originates from ATMU                             | 1. The controller always retries the transaction as soon as possible until a status other than CRS is returned. However, if a CRS status is returned after the configuration retry timeout (PEXCONF_RTY_TOR) timer expires, then the controller aborts the transaction.                                                      |
|                  |                                                                                                                                       | 2. Log the error (PEX_ERR_DR[CRST]) and send interrupt to the PIC, if enabled.                                                                                                                                                                                                                                               |
| Inbound response | UR response for Configuration transaction that originates from ATMU                                                                   | Log the error (PEX_ERR_DR[CDNSC] and PCI Express Uncorrectable Status Register[20]) and send interrupt to PIC, if enabled.                                                                                                                                                                                                   |
| Inbound response | CA response for Configuration transaction that originates from ATMU                                                                   | Log the error (PEX_ERR_DR[PCAC, CDNSC] and PCI Express Uncorrectable Status Register[15]) and send interrupt to PIC, if enabled.                                                                                                                                                                                             |
| Inbound response | Malformed TLP response                                                                                                                | PCI Express controller does not pass the response back to the core. Therefore, a completion timeout error eventually occurs.                                                                                                                                                                                                 |

Table 14-276. Error conditions (continued)

| Transaction Type  | Error Type                                                                                                                        | Action                                                                                                                                                                           |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Inbound request   | Poisoned TLP (EP=1)                                                                                                               | I. If it is a posted transaction, the controller drops it.                                                                                                                       |
|                   |                                                                                                                                   | 2. If it is a non-posted transaction, the controller returns a completion with UR status.                                                                                        |
|                   |                                                                                                                                   | 3. Release the proper credits                                                                                                                                                    |
| Inbound request   | ECRC error                                                                                                                        | 1. If it is a posted transaction, the controller drops it.                                                                                                                       |
|                   |                                                                                                                                   | 2. If it is a non-posted transaction, the controller returns a completion with UR status.                                                                                        |
|                   |                                                                                                                                   | 3. Release the proper credits                                                                                                                                                    |
| Inbound request   | PCI Express nullified request                                                                                                     | The packet is dropped.                                                                                                                                                           |
| Outbound request  | Outbound ATMU crossing                                                                                                            | Log the error (PEX_ERR_DR[OAC]). The transaction is not sent out on the link.                                                                                                    |
| Outbound request  | Illegal message size                                                                                                              | Log the error (PEX_ERR_DR[MIS]). The transaction is not sent out on the link.                                                                                                    |
| Outbound request  | Illegal I/O size                                                                                                                  | Log the error (PEX_ERR_DR[IOIS]). The transaction is not sent out on the link.                                                                                                   |
| Outbound request  | Illegal I/O address                                                                                                               | Log the error (PEX_ERR_DR[IOIA]). The transaction is not sent out on the link.                                                                                                   |
| Outbound request  | Illegal configuration size                                                                                                        | Log the error (PEX_ERR_DR[CIS]). The transaction is not sent out on the link.                                                                                                    |
| Outbound response | Internal platform response with error (for example, an ECC error on a DDR read or the transaction maps to unknown address space). | Send poisoned TLP (EP=1) completion(s) for data that are known bad. If the poison data happens in the middle of the packet, the rest of the response packet(s) is also poisoned. |

#### 14.12.1.13.4 Error capture registers

The PCI Express error capture registers, PEX\_ERR\_CAP\_R0 through PEX\_ERR\_CAP\_R3, allow vital error information to be captured when an error occurs.

Different error information is reported depending on whether the error source is from an outbound transaction from an internal source or from an inbound transaction from an external source; the source of the captured error is reflected in PEX\_ERR\_CAP\_STAT[GSID]. Note that after the initial error is captured, no further

#### 14.12.1.13.4.1 Error capture registers (outbound error)

capturing is performed until the PEX\_ERR\_CAP\_STAT[ECV] bit is clear.

PEX\_ERR\_CAP\_Rn for the case when the error is caused by an outbound transaction from an internal source and the error is due to timeout condition or PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA access are shown in the following figure and tables.



Figure 14-281. PCI Express error capture registers, outbound case

Table 14-277. PCI Express error capture register n field descriptions internal source, outbound transaction

| ERR_CA<br>P_n | Bits  | Name     | Description                                                            |
|---------------|-------|----------|------------------------------------------------------------------------|
| R0            | 0-15  | Reserved | -                                                                      |
|               | 16-17 | FMT      | Header format                                                          |
|               | 18-22 | TYPE     | Transaction type                                                       |
|               | 23-31 | Reserved | -                                                                      |
| R1            | 0-23  | Reserved | -                                                                      |
|               | 24-31 | OD0      | Internal platform transaction information. Reserved for factory debug. |
| R2            | 0-31  | OD1      | Internal platform transaction information. Reserved for factory debug. |
| R3            | 0-31  | OD2      | Internal platform transaction information. Reserved for factory debug. |

#### 14.12.1.13.4.2 Error capture registers (inbound error)

PEX\_ERR\_CAP\_Rn for the case when the error is caused by an inbound transaction from an external source are shown in the following figure and tables.

Inbound transactions that result in PEX\_ERR\_DR[PNM] or PEX\_ERR\_DR[PCAC] or PEX\_ERR\_DR[CDNSC] or PEX\_ERR\_DR[CRSNC] being set will result in PEX\_ERR\_CAP\_STAT[GSID] indicating the controller itself was the source of the error.



Figure 14-282. PCI Express error capture registers, inbound case, completion transaction

Table 14-278. PCI Express error capture register 1 field descriptions external source, inbound completion transaction

| ERR_CAP_n | Bits            | Name                  | Description              |
|-----------|-----------------|-----------------------|--------------------------|
| R0        | 24              | Reserved              | -                        |
|           | 25-26           | FMT                   | Header format            |
|           | 27-31           | TYPE                  | Transaction type         |
|           | 16              | Reserved              | -                        |
|           | 17-19           | TC                    | Traffic class            |
|           | 20-23           | Reserved              | -                        |
|           | 8               | TD                    | TLP digest field present |
|           | 9               | EP                    | Poisoned packet          |
|           | 10-11           | ATTR                  | Attributes               |
|           | 12-13           | Reserved              | -                        |
|           | 14-15, 0-7      | LENGTH[9:0]           | Packet length            |
| R1        | 24-31,<br>16-23 | Comp<br>ID[15:0]      | Completion ID, bits 15:0 |
|           | 8-10            | Comp Status           | Completion status        |
|           | 11              | ВСМ                   | Byte count modified      |
|           | 12-15, 0-7      | Byte<br>Count[11:0]   | Byte count, bits 11:0    |
| R2        | 24-31,<br>16-23 | Requester ID[15:0]    | Requester ID, bits 15:0  |
|           | 8-15            | Tag[7:0]              | Tag, bits 7:0            |
|           | 0               | Reserved              | -                        |
|           | 1-7             | Lower<br>Address[6:0] | Lower address, bits 6:0  |
| R3        | 0-31            | Reserved              | Not used                 |

| 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 | _  |
|--------------------|----------------|------|---|---|---------------|----------|----|----|----|----------------|-------------------|--------|----|----|----|----|----|--------------------|----|----|----|----|----|----|----|-----|----|----|----|
| LENG               | TH[7           | 7:0] |   |   | TD            | ΕP       | ΑT | TR | _  | -              | LENGT             | H[9:8] | _  |    | TC |    |    |                    | _  |    |    | F۱ | ΛT |    | ٦  | ΥPI | Ε  |    | RO |
| Last DW<br>BE[3:0] |                |      |   |   |               | Tag[7:0] |    |    |    |                | Requester ID[7:0] |        |    |    |    |    |    | Requester ID[15:8] |    |    |    |    | R1 |    |    |     |    |    |    |
| Address[7          | Address[7:2] — |      |   | - | Address[15:8] |          |    |    |    | Address[23:16] |                   |        |    |    |    |    |    | Address[31:24]     |    |    |    |    |    | R2 |    |     |    |    |    |
|                    | Reserved       |      |   |   |               |          |    |    |    |                |                   |        |    |    | Βз |    |    |                    |    |    |    |    |    |    |    |     |    |    |    |

Figure 14-283. PCI Express error capture registers, inbound case, memory request transaction (3 DW)

Table 14-279. PCI Express error capture register 1 field descriptions external source, inbound memory request transaction (3 DW)

| ERR_CAP_n | Bits            | Name                | Description                             |
|-----------|-----------------|---------------------|-----------------------------------------|
| R0        | 24              | Reserved            | -                                       |
|           | 25-26           | FMT                 | Header format                           |
|           | 27-31           | TYPE                | Transaction type                        |
|           | 16              | Reserved            | -                                       |
|           | 17-19           | TC                  | Traffic class                           |
|           | 20-23           | Reserved            | -                                       |
|           | 8               | TD                  | TLP digest field present                |
|           | 9               | EP                  | Poisoned packet                         |
|           | 10-11           | ATTR                | Attributes                              |
|           | 12-13           | Reserved            | -                                       |
|           | 14-15, 0-7      | LENGTH[9:0]         | Packet length                           |
| R1        | 24-31,<br>16-23 | Requester ID[15:0]  | Requester ID, bits 15:0                 |
|           | 8-15            | Tag[7:0]            | Tag, bits 7:0                           |
|           | 0-3             | Last DW<br>BE[3:0]  | Last doubleword byte enables, bits 3:0  |
|           | 4-7             | First DW<br>BE[3:0] | First doubleword byte enables, bits 3:0 |
| R2        | 24-31,<br>16-23 | Address[31:2        | Address, bits 31:2                      |
|           | 8-15, 0-5       |                     |                                         |
|           | 6-7             | Reserved            | -                                       |
| R3        | 0-31            | Reserved            | Not used                                |

| 0 1 2 3            | 4              | 5 | 6 | 7             | 8              | 9   | 10 | 11                | 12 1           | 13             | 14     | 15 | 16     | 17 | 18                | 19 | 20             | 21   | 22 | 23 | 24 | 25 | 26 | 27 | 28 2 | 9 3 | 30 31 | _ |
|--------------------|----------------|---|---|---------------|----------------|-----|----|-------------------|----------------|----------------|--------|----|--------|----|-------------------|----|----------------|------|----|----|----|----|----|----|------|-----|-------|---|
| LENG               | LENGTH[7:0]    |   |   | TD            | EΡ             | ATT | R  | _                 | .              | LENGT          | H[9:8] | _  | - тс — |    |                   | FM | т              | TYPE |    | RO |    |    |    |    |      |     |       |   |
| Last DW<br>BE[3:0] | Tag17:0        |   |   |               | ':O]           |     |    | Requester ID[7:0] |                |                |        |    |        |    | RequesterID[15:8] |    |                |      |    |    | R1 |    |    |    |      |     |       |   |
| Addres             | Address[39:32] |   |   |               | Address[47:40] |     |    |                   |                | Address[55:48] |        |    |        |    |                   |    | Address[63:56] |      |    |    |    | R2 |    |    |      |     |       |   |
| Address[7:2] —     |                |   | - | Address[15:8] |                |     |    |                   | Address[23:16] |                |        |    |        |    |                   |    | Address[31:24] |      |    |    |    | Rз |    |    |      |     |       |   |

Figure 14-284. PCI Express error capture registers, inbound case, memory request transaction (4 DW)

Table 14-280. PCI Express error capture register 1 field descriptions external source, inbound memory request transaction (4 DW)

| ERR_CAP_n | Bits            | Name                | Description                             |
|-----------|-----------------|---------------------|-----------------------------------------|
| R0        | 24              | Reserved            | -                                       |
|           | 25-26           | FMT                 | Header format                           |
|           | 27-31           | TYPE                | Transaction type                        |
|           | 16              | Reserved            | -                                       |
|           | 17-19           | TC                  | Traffic class                           |
|           | 20-23           | Reserved            | -                                       |
|           | 8               | TD                  | TLP digest field present                |
|           | 9               | EP                  | Poisoned packet                         |
|           | 10-11           | ATTR                | Attributes                              |
|           | 12-13           | Reserved            | -                                       |
|           | 14-15, 0-7      | LENGTH[9:0]         | Packet length                           |
| R1        | 24-31,<br>16-23 | Requester ID[15:0]  | Requester ID, bits 15:0                 |
|           | 8-15            | Tag[7:0]            | Tag, bits 7:0                           |
|           | 0-3             | Last DW<br>BE[3:0]  | Last doubleword byte enables, bits 3:0  |
|           | 4-7             | First DW<br>BE[3:0] | First doubleword byte enables, bits 3:0 |
| R2        | 24-31,<br>16-23 | Address[63:3<br>2]  | Address, bits 63:32                     |
|           | 8-15, 0-7       |                     |                                         |
| R3        | 24-31,<br>16-23 | Address[31:2        | Address, bits 31:2                      |
|           | 8-15, 0-5       |                     |                                         |
|           | 6-7             | Reserved            | -                                       |

## 14.12.2 Interrupts

Both INTx and message signaled interrupts (MSI) are supported; however there are differences depending on whether the PCI Express controller is configured as an RC or EP device.

## 14.12.2.1 EP interrupt generation

#### 14.12.2.1.1 Hardware INTx message generation

Hardware INTx message generation is not supported in EP mode.

#### 14.12.2.1.2 Hardware MSI generation

In EP mode, the PCI Express controller can be configured to automatically generate MSI transactions to the root complex when an interrupt event occurs.

The PCI Express controller uses *irq\_out* (an internal version of the IRQ\_OUT signal) to trigger the generation of the MSI. To trigger the MSI, interrupt events must be routed to *irq\_out* by setting the EP (external pin) bit in the associated Interrupt Destination register in the PIC. Note that the IRQ\_OUT signal should not be used for any other function if it is being used to trigger MSI transactions.

The remote root complex is expected to set up the MSI capability structure of all endpoints at system initialization by filling the Message Address and Message Data registers with appropriate values and setting the MSIE bit in the MSI Message Control register.

With the PCI Express controller properly configured, when it detects the leading edge of *irq\_out* going active, it generates a PCI Express memory write transaction to the address specified in the MSI Message Address register (and MSI Message Upper Address register) with a data payload as specified in the MSI Message Data register (with leading zeros appended).

#### 14.12.2.1.3 Software INTx message generation

Software can generate outbound assert or deassert INTx message transactions by using the outbound ATMU mechanism described in Outbound ATMU message generation.

#### 14.12.2.1.4 Software MSI generation

Host software has to set up the MSI capability registers to enable MSI mode, and have the correct values for the MSI address and data register.

Then local software has to read the MSI address in the MSI capability register and configure the outbound ATMU window to map the translated address to the MSI address. Software has to determine the number of allocated messages in the MSI capability register and allocates the appropriate data values to use. A write to the ATMU window containing the MSI address with the appropriate data value generates the desired MSI transaction to the remote RC.

#### 14.12.2.2 RC handling of INTx message and MSI interrupts

#### 14.12.2.2.1 INTx message handling

MSIs are the preferred interrupt signaling mechanism for PCI Express.

However, in RC mode, the PCI Express controller supports the INTx virtual-wire interrupt signaling mechanism (as described in the PCI Express specification). Whenever the controller receives an inbound INTx (INTA, INTB, INTC, or INTD) asserted or negated message, it asserts or negates an equivalent internal INTx signal (*inta*, *intb*, *intc*, or *intd*) to the interrupt controller.

The internal INTx signals from the PCI Express controller may be logically combined with the interrupt request (IRQn) input signals so that they share the same interrupt controlled by the associated EIVPRn and EIDRn registers in the interrupt controller. Refer to Programmable interrupt controller (PIC) for more information about sharing of PCI Express INTx interrupts and the external interrupt request (IRQn) signals.

If a PCI Express INTx interrupt is being used, then the interrupt controller must be configured so that external interrupts are level-sensitive (EIVPRn[S] = 1).

#### 14.12.2.2.2 MSI handling

An inbound MSI cycle must hit into the PEXCSRBAR window with the address offset that points to the MSIIR register in the PIC.

Note that it is the responsibility of the host software to configure each EP's MSI capability registers such that an MSI cycle generated from the EP device is routed to the MSIIR register in the PIC and for the appropriate interrupt to be generated to the core.

#### 14.12.3 Initial credit advertisement

To prevent overflowing of the receiver's buffers and for ordering compliance purposes, the transmitter cannot send transactions unless it has enough flow control (FC) credits to send. Each device maintains an FC credit pool.

The FC information is conveyed between the two link partners by DLLPs during link training (initial credit advertisement). The transaction layer performs the FC accounting functions. One FC unit is four DWs (16-bytes) of data.

Table 14-281. Initial credit advertisement

| Credit type                                                            | Initial credit advertisement |
|------------------------------------------------------------------------|------------------------------|
| PH (Memory Write, Message Write)                                       | 6                            |
| PD (Memory Write, Message Write)                                       | (256/16)x6=96                |
| NPH (Memory Read, IO Read, Cfg Read, Cfg Write)                        | 8                            |
| NPD (IO Write, Cfg Write)                                              | 2                            |
| CPLH (Memory Read Completion, IO R/W Completion, Cfg R/W Completion)   | Infinite                     |
| CPLD (Memory Read Completion, IO Read Completion, Cfg Read Completion) | Infinite                     |

## 14.12.4 Power management

All device power states are supported with the exception of D3cold with Vaux. In addition, all link power states are supported with the exception of L2 states.

This device does not support the PCI express ASPM feature. Note that there is no power saving in the controller when the device is put into a non-D0 state. The only power saving is the I/O drivers when the controller is put into a non-L0 link state.

Table 14-282. Power management state supported

| Component<br>D-state | Permissible interconnect state | Action                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0                   | LO                             | In full operation.                                                                                                                                                                                                                                                                                                                                                                                                            |
| D1                   | L0, L1                         | All outbound traffics are stalled. All inbound traffic is thrown away. The only exceptions are PME messages and configuration transactions. If the device is in RC mode, it is permissible to send a PM_Turn_Off message through the PEX power management command register.                                                                                                                                                   |
| D2                   | L0, L1                         | All outbound traffics are stalled. All inbound traffic is thrown away. The only exceptions are PME messages and configuration transactions. If the device is in RC mode, it is permissible to send a PM_Turn_Off message through the PEX power management command register.                                                                                                                                                   |
| D3hot                | L0, L1, L2/L3<br>ready         | All outbound traffics are stalled. All inbound traffic is thrown away. The only exceptions are PME messages and configuration transactions. If the device is in RC mode, it is permissible to send a PM_Turn_Off message through the PEX power management command register. Note that if a transition of D3hot->D0 occurs, a reset is performed to the controller's configuration space. In addition, link training restarts. |
| D3cold               | L3                             | Completely off.                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 14.12.4.1 L2/L3 ready link state

The L2/L3 ready link state is entered after the EP device is put into a D3hot state followed by a PME\_Turn\_Off/PME\_TO\_Ack message handshake protocol.

Exiting this state requires a POR reset or a WAKE\_B signal from the EP device. The PCI Express controller (in EP mode) does not support the generation of beacon; therefore, as an alternative, the device can use one of the GPIO signals as an enable to an external tristate buffer to generate a WAKE\_B signal, as shown in Figure 14-285.



Figure 14-285. WAKE\_B Generation example

In RC mode, the WAKE\_B signal from the EP device can be connected to one of the external interrupt inputs to service the WAKE\_B request.

#### 14.12.5 Hot reset

When a hot reset condition occurs, the controller (in both RC and EP mode) initiates a clean-up of all outstanding transactions and returns to an idle state.

All configuration register bits that are non-sticky are reset. Link training takes place subsequently. The device is permitted to generate a hot reset condition on the bus when it is configured as an RC device by setting the "Secondary Bus Reset" bit in the Bridge Control Register in the configuration space. As an EP device, it is not permitted to generate a hot reset condition; it can only detect a hot reset condition and initiate the clean-up procedure appropriately.

#### 14.12.6 Link down

Typically, a link down condition occurs after a hot reset event; however, it is possible for the link to go down unexpectedly without a hot reset event.

When this occurs, a link down condition is detected (PEX\_PME\_MSG\_DR[LDD]=1). Link down is treated similarly to a hot reset condition.

Subsequently, while the link is down, all new posted outbound transactions are discarded. All new non-posted ATMU transactions are errored out. Non-posted configuration transactions issued using PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA toward the link returns 0xFFFF\_FFFF (all 1s). As soon as the link is up again, the sending of transaction resumes.

Note that in EP mode, a link down condition causes the controller to reset all non-sticky bits in its PCI Express configuration registers as if it had been hot reset.

## 14.13 Initialization/application information

The following topics describe the initialization/application information for PCI Express.

#### 14.13.1 EP Boot mode and inbound configuration transactions

In normal boot mode ( $cfg\_cpu\_boot = 1$ ), the core is allowed to boot and configure the device.

During this time, the PCI Express interface retries all inbound PCI Express configuration transactions. When the core has configured the device to a state where it can accept inbound PCI Express configuration transactions, the boot code should set the CFG\_READY bit in the PEX\_CFG\_READY register after which inbound PCI Express configuration transactions are accepted. Refer to Configuration Ready Register (Configuration\_Ready\_Register), for more information about the CFG\_READY bit.

In boot hold-off mode (cfg\_cpu\_boot = 0), the core is prevented from fetching its first instruction by withholding its internal bus grant. During this time, the PCI Express interface accepts all inbound PCI Express configuration transactions which allows an external host/RC to configure the device. When the external host/RC has configured the device to a state where it can allow the core to fetch code from the boot vector, it sets the EEBPCR[CPUn\_EN] bit after which the core is granted the internal bus.

If boot hold-off mode is desired in EP mode implementation, I<sup>2</sup>C boot sequencer must be used to pre-configure the respective EICn bit field of the SRDSCR3 and/or SRDSCR4 registers depending on the SerDes lane used for the PCI Express controller to ensure a successful link training. Refer to the notes described in SRDSCR3 and SRDSCR4 for more information.

#### 14.13.2 Automatic link retraining during initialization

During initialization, if the link partner is down or the device has not received DLLP updates within timeout interval specified in

PEX\_FC\_UPDATE\_TOR[FC\_UPDATE\_TIMEOUT], it will fail link training.

It is recommended that software clear PEX\_FC\_UPDATE\_TOR[DIS\_LR] to allow for automatic retraining of the link. See Flow Control Update Timeout Register (Flow\_Control\_Update\_Timeout\_Register), for more information.

## 14.13.3 Configuration accesses and inbound writes to CCSR space

In RC mode, when the core issues an outbound configuration access to an external device using the PCI Express configuration access registers (PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA), there is a potential deadlock if several inbound memory write transactions targeting the CCSR space are received before the completion for the configuration access is returned.

Inbound writes to CCSR space include MSIs and message interrupts to the MPIC. The deadlock also can occur when the endpoint generates a single write to CCSR followed by multiple writes to another target before the original configuration access by the RC completes. When the deadlock occurs the configuration access will time out and an error will be reported (if enabled). This deadlock can be avoided by any of the following methods:

- 1. Configure external agents to allow completions to bypass memory write requests. Many devices allow this when relaxed ordering (RO) is in effect; however, this ability is optional under the *PCI Express Base Specification* ordering rules, so it is possible that some devices may not support it.
- 2. For the RC, restrict external configuration accesses through PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA to the enumeration of the bus and other initialization functions; do not use PEX\_CONFIG\_ADDR/PEX\_CONFIG\_DATA to access external devices during periods when PCI Express endpoints are generating inbound writes to CCSR space.
- 3. Govern the generation of write transactions by the endpoint device such that after a write to the CCSR space no other writes are generated until pending configuration accesses are completed or the write is guaranteed to have completed by the completion of a subsequent read request by the endpoint devices.

| 4. | Use the PCI Express outbound ATMU window to generate outbound configuration        |
|----|------------------------------------------------------------------------------------|
|    | accesses during periods when an endpoint device may be writing to CCSR space. See  |
|    | RC configuration register access for more information. The deadlock does not occur |
|    | when the ATMU window is used for configuration accesses.                           |
|    | •                                                                                  |

Initialization/application information

# **Chapter 15 Enhanced Three-Speed Ethernet Controllers**

The enhanced three-speed Ethernet controllers (eTSECs) of the device interface to 10 Mbps, 100 Mbps, and 1 Gbps Ethernet/IEEE 802.3® networks.

#### 15.1 Overview

The enhanced three-speed Ethernet controllers (eTSECs) of the device interface to 10 Mbps, 100 Mbps, and 1 Gbps Ethernet/IEEE 802.3® networks.

For Ethernet, an external PHY or SerDes device is required to complete the interface to the media. Each eTSEC supports multiple standard media-independent interfaces. Multiple eTSECs are available, providing flexible options for connectivity and control access at different speeds.

The eTSEC provides the flexibility to accelerate the identification and retrieval of standard and non-standard protocols carried over Ethernet, including both IP versions 4 and 6 and TCP/UDP. CPU-intensive parsing and checksum operations can be optionally offloaded to an eTSEC to accelerate existing TCP/IP stacks. On transmission, varying fractions of link bandwidth can be allocated to each of multiple transmit queues through a modified weighted round-robin scheduler. On receive, an arbitrary set of queue selection rules can be programmed into each eTSEC to implement flexible quality of service or firewall strategies based on high-level protocol identification. Without enabling these advanced features, each eTSEC emulates a PowerQUICC III TSEC, allowing existing driver software to be re-used with minimal change. Each eTSEC is organized as shown in the figure below.

#### **Features**



<sup>\*</sup> Note: Not all interfaces may be supported on this device.

Figure 15-1. eTSEC block diagram

#### NOTE

This device supports MII, RMII, RGMII, and SGMII.

#### 15.2 Features

The eTSECs of the device include these distinctive features:

- IEEE 802.3, 802.3u, 820.3x, 802.3z, 802.3ac, 802.3ab compliant
- Support for different Ethernet physical interfaces:
  - 10/100 Mbps IEEE 802.3 MII
  - 10/100 Mbps IEEE 802.3 RMII
  - 10/100 Mbps RGMII
  - 1000 Mbps full-duplex RGMII
  - 10/100 Mbps SGMII
  - 1000 Mbps full-duplex SGMII (carrier extend symbols in full duplex mode are not supported)
- TCP/IP offload
  - IP v4 and IP v6 header recognition on receive
  - IP v4 header checksum verification and generation
  - TCP and UDP checksum verification and generation
  - Per-packet configurable offload
  - Recognition of VLAN, stacked-VLAN, 802.2, PPPoE session, MPLS stacks, and ESP/AH IP-Security headers
- Quality of service (QoS) support
  - Transmission from up to eight queues
    - Priority-based queue selection
    - Modified weighted round-robin queue selection with fair bandwidth allocation
  - Reception to up to eight physical queues
    - 64 virtual receive queues overlaid on 8 physical buffer descriptor rings
    - Table-oriented queue filing strategy based on 16 header fields or flags
    - Frame rejection support for filtering applications
    - Filing based on Ethernet, IP, and TCP/UDP properties, including VLAN fields, Ether-type, IP protocol type, IP TOS or differentiated services, IP source and destination addresses, TCP/UDP port numbers
- Interrupt coalescing
  - Packet-count-based thresholds for both receive and transmit
  - Timer-based thresholds
- Interrupt virtualization
  - Each ring mappable to one of two separate groups for interrupt and BD management; each group associated by software with a CPU.
  - Separate address spaces per group and for MDIO
  - Interrupt coalescing controls per ring in multi-group mode
- Full- and half-duplex Ethernet support (1000 Mbps supports only full duplex):

#### Modes of operation

- IEEE 802.3 full-duplex flow control (automatic PAUSE frame generation or software programmed PAUSE frame generation and recognition)
- Programmable maximum frame length supports jumbo frames (up to 9.6 Kbytes) and IEEE 802.1 virtual local area network (VLAN) tags and priority
- VLAN insertion and deletion
  - Per-frame VLAN control word or default VLAN for each eTSEC
  - Extracted VLAN control word passed to software separately
  - Programmable VLAN tag to support metropolitan bridging
- Retransmission following a collision
- Support for CRC generation and verification of inbound/outbound packets
- Programmable Ethernet preamble insertion and extraction of up to 7 bytes
- MAC address recognition:
  - Exact match on 48-bit unicast addresses
    - VRRP and HSRP support for seamless router fail-over
    - In addition to primary station address, up to fifteen additional exact-match MAC addresses supported
  - Broadcast address (accept/reject)
  - Hash table match on up to 256 unicast/multicast or 512 multicast-only addresses
  - Promiscuous mode
- Remote network monitoring (RMON) statistics support
  - 32-bit byte counters
  - Carry/Overflow of counter interrupts
- Backward compatibility with MPC8540E/MPC8560E (PowerQUICC III) TSEC
  - PowerQUICC III buffer descriptor (BD) format and rings supported
  - Common register memory map, with specific exceptions:
    - Out-of-sequence transmit BD not supported
    - Internal DMA BD pointers and data counts not visible
    - MINFLR register not supported
  - Reset state of eTSEC defaults to common PowerQUICC III TSEC subset
  - TSEC\_ID register permits TSEC versus enhanced TSEC differentiation
- Hardware assist for 1588 compliant time stamping
  - Per packet time stamp tag for Receive
  - Programmable time stamp capture for Transmit
  - Recognition of PTP packet
  - Periodic Pulse Generation
  - Self-correcting precision timer with nano-second resolution
  - Phase aligned adjustable (divide by N) clock output
  - Two 64-bit alarm (future time) registers for future time comparison

## 15.3 Modes of operation

The eTSEC's primary operational modes are the following:

Full- and half-duplex operation

This is determined by the MACCFG2 register's full-duplex bit (MACCFG2[Full Duplex]). Full-duplex mode is intended for use on point-to-point links between switches or end node to switch. Half-duplex mode is used in connections between an end node and a repeater or between repeaters.

If configured in half-duplex mode (10- and 100-Mbps operation; MACCFG2[Full Duplex] is cleared), the MAC complies with the IEEE CSMA/CD access method.

If configured in full-duplex mode (10/100/1000 Mbps operation; MACCFG2[Full Duplex] is set), the MAC supports flow control. If flow control is enabled, it allows the MAC to receive or send PAUSE frames.

10- and 100-Mbps MII interface operation

The MAC-PHY interface operates in MII mode by setting MACCFG2[I/F Mode] = 01. The MII is the media-independent interface defined by the 802.3 standard for 10/100 Mbps operation. The speed of operation is determined by the TSEC $n_TX_CLK$  and TSEC $n_RX_CLK$  signals, which are driven by the transceiver. The transceiver either auto-negotiates the speed, or it may be controlled by software using the serial management interface (MDC/MDIO signals) to the transceiver.

Clause 22.2.4 of the IEEE 802.3 specification describes the MII management interface.

• 10- and 100-Mbps RMII interface operation

The RMII is the reduced media-independent interface defined by the RMII Consortium (March 1998) for 10/100 Mbps operation. The speed of operation is determined by the TSEC*n*\_TX\_CLK signal, which is driven by the transceiver.

• MAC address recognition options

The options supported are promiscuous, broadcast, exact unicast address match, exact unicast virtual address match to support router redundancy, and multicast hash match. For detailed descriptions refer to Frame recognition.

eTSEC supports automatic LAN-initiated wake-up during power management through the AMD Magic Packet<sup>TM</sup> protocol, as described in Magic Packet mode.

• Receive frame parsing options

#### eTSEC external signals description

Frame parsing options are to disable parsing (no TCP/IP offload), IP header parsing, and TCP or UDP parsing. Parsing must be enabled to make use of receive queue filing algorithms. The options are detailed in TCP/IP offload.

Receive queue selection options

Received frames are by default sent to a single buffer descriptor ring. If multiple receive queues are enabled, a receive queue filer can be programmed with selection criteria to differentiate received frames and file them to different buffer descriptor rings. See Quality of service (QoS) provision, for detailed descriptions.

TCP/IP transmit options

Frames for transmission may be sent as-is, with IP header processing, or TCP header processing. The transmit buffer descriptors, described in Transmit data buffer descriptors (TxBD), enable these options and operate with parameters prepended to frame buffers, as described in TCP/IP offload.

Transmit queue selection options

The options supported are single transmit queue, priority-based queue selection, and modified weighted round-robin queueing. These options are described further in Transmit control register (eTSEC\_TCTRL).

• RMON support

Standard Ethernet interface management information base (MIBs) can be generated through the RMON MIB counters.

• Internal loop back supported for all interfaces except when configured for halfduplex operation

Internal loop back mode is selected through the loop back bit in the MACCFG1 register. See Interface mode configuration, for details.

#### 15.4 eTSEC external signals description

This section defines the eTSEC interface signals.

The buses are described using the bus convention used in IEEE 802.3 because the PHY follows this same convention. (That is, TxD[3:0] means 0 is the lsb.) Note that except for external physical interfaces the buses and registers follow a big-endian format, where 0 denotes the msb.

Each eTSEC network interface supports multiple options, as follows:

- The MII option requires 18 I/O signals (including the MDIO and MDC MII management interface) and supports both a data and a management interface to the PHY (transceiver) device. The MII option supports both 10- and 100-Mbps Ethernet rates.
- The RMII, RGMII options are reduced-pin implementations of the MII, GMII interfaces, respectively.
- SGMII interfaces are offered via the SerDes interface signals.
- 1588 timer signals

The table below lists the network interface signals.

Table 15-1. eTSECnnetwork interface signal properties

| Signal name      | Function                                                                                                               | Reset state     |
|------------------|------------------------------------------------------------------------------------------------------------------------|-----------------|
| TSECn_COL        | MII-Collision detect, input                                                                                            | -               |
|                  | RMII, RGMII -Unused                                                                                                    |                 |
| TSECn_CRS        | MII-Carrier sense, input                                                                                               | -               |
|                  | RMII, RGMII-Unused                                                                                                     |                 |
| TSECn_GTX_CLK    | MII-Transmit clock feedback when transmission is enabled, zero otherwise; output                                       | 0               |
|                  | RMII-Transmit clock feedback when transmission is enabled, zero otherwise; output                                      |                 |
|                  | RGMII-Inverted transmit clock feedback, output                                                                         |                 |
| EC _GTX_CLK125   | MII-Unused                                                                                                             | -               |
|                  | RMII-Unused                                                                                                            |                 |
|                  | RGMII-Oscillator source for transmit clock; This clock can be configured to feed eTSEC3 only or feed eTSEC1 and eTSEC3 |                 |
| TSEC1_GTX_CLK125 | MII-unused                                                                                                             | -               |
|                  | RGMII-This can be configured to feed 125 MHz to eTSEC1                                                                 |                 |
| EC_MDC           | Management clock, output                                                                                               | 0               |
| EC_MDIO          | Management data, bidirectional                                                                                         | Hi-Z<br>(input) |
| TSECn_RX_CLK     | MII-Receive clock, input                                                                                               | -               |
|                  | RMII-Unused                                                                                                            |                 |
|                  | RGMII-Receive clock, input                                                                                             |                 |
| TSECn_RX_DV      | MII-Receive data valid, input                                                                                          | -               |
|                  | RMII-CRS_DV carrier sense/data valid, input                                                                            |                 |
|                  | RGMII (RX_CLK rising)-Receive data valid, input                                                                        |                 |
|                  | RGMII (RX_CLK falling)-Receive error, input                                                                            |                 |

#### eTSEC external signals description

Table 15-1. eTSECnnetwork interface signal properties (continued)

| Signal name         | Function                                                                                                 | Reset state |
|---------------------|----------------------------------------------------------------------------------------------------------|-------------|
| TSECn_RXD[3:0]      | MII-Receive data bits 3-0, input                                                                         | -           |
|                     | RMII-RXD[1:0] receive data bits, input                                                                   |             |
|                     | RMII-RXD[3:2] are unused                                                                                 |             |
|                     | RGMII (RX_CLK rising)-Receive data bits 3-0, input                                                       |             |
|                     | RGMII (RX_CLK falling)-Receive data bits 7-4, input                                                      |             |
| TSECn_RX_ER         | MII-Receive error, input                                                                                 | -           |
|                     | RMII-Receive error, input                                                                                |             |
|                     | RGMII-Unused                                                                                             |             |
| TSECn_TX_CLK        | MII-Transmit clock, input                                                                                | -           |
|                     | RMII-Reference transmit and receive clock, input                                                         |             |
|                     | RGMII-Unused                                                                                             |             |
| TSECn_TXD[3:0]      | MII-Transmit data bits 3-0, output                                                                       | 0000        |
|                     | RMII-TXD[1:0] transmit data bits, output                                                                 |             |
|                     | RMII-TXD[3:2] unused, output driven zero                                                                 |             |
|                     | RGMII (TX_CLK rising)-Transmit data bits 3-0, output                                                     |             |
|                     | RGMII (TX_CLK falling)-Transmit data bits 7-4, output                                                    |             |
| TSECn_TX_ER         | MII-Transmit error, output                                                                               | 0           |
|                     | RMII, RGMII-Unused, output driven zero                                                                   |             |
| TSECn_TX_EN         | MII-Transmit data valid, output                                                                          | 0           |
|                     | RMII-Transmit data valid, output                                                                         |             |
|                     | RGMII (TX_CLK rising)-Transmit data enabled, output                                                      |             |
|                     | RGMII (TX_CLK falling)-Transmit error, output                                                            |             |
| TSEC_1588_ CLK_IN   | 1588-Clock input                                                                                         | -           |
|                     | External high precision timer reference clock input (chip external input pin).                           |             |
| TSEC_1588_ CLK_OUT  | 1588-Clock out                                                                                           | 0           |
|                     | Phase aligned timer clock divider output (chip external output pin).                                     |             |
| TSEC_1588_ TRIG_IN1 | 1588-Trigger in 1                                                                                        | -           |
|                     | External timer trigger input 1 .This is an asynchronous general purpose input (chip external input pin). |             |
| TSEC_1588_ TRIG_IN2 | 1588-Trigger in 2                                                                                        | -           |
|                     | External timer trigger input 2. This is an asynchronous general purpose input (chip external input pin). |             |
| TSEC_1588_          | 1588-Pulse out 1                                                                                         | 0           |
| PULSE_OUT1          | Timer pulse per period 1. It is phase aligned with 1588 timer clock (chip external output pin).          |             |

Table 15-1. eTSECnnetwork interface signal properties (continued)

| Signal name                                   | Function                                                                                                          | Reset state |  |  |  |  |  |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|
| TSEC_1588_                                    | 1588-Pulse out 2                                                                                                  | 0           |  |  |  |  |  |
| PULSE_OUT2                                    | Timer pulse per period 2. It is phase aligned with 1588 timer clock (chip external output pin).                   |             |  |  |  |  |  |
| TSEC_1588_                                    | 1588-Timer alarm 1                                                                                                | 0           |  |  |  |  |  |
| ALARM_OUT1                                    | Timer current time is equal to or greater than alarm time comparator register.                                    |             |  |  |  |  |  |
|                                               | User reprograms the TSEC_ 1588_ALARM <i>n</i> _H/L register to deactivate this output (chip external output pin). |             |  |  |  |  |  |
| TSEC_1588_                                    | 1588-Timer alarm 2                                                                                                | 0           |  |  |  |  |  |
| ALARM_OUT2                                    | Timer current time is equal to or greater than alarm time comparator register.                                    |             |  |  |  |  |  |
|                                               | User reprograms the TSEC_1588_ALARM <i>n</i> _H/L register to deactivate this output (chip external output pin).  |             |  |  |  |  |  |
| SD_TX[ <i>n-1</i> ],<br>SD_TX_B[ n-1]         | SGMII transmit data (and complement)                                                                              | -           |  |  |  |  |  |
| SD_RX[ <i>n-1</i> ],<br>SD_RX_B[ <i>n-1</i> ] | SGMII receive data (and complement)                                                                               | -           |  |  |  |  |  |
| SD_REF_CLK,<br>SD_REF_CLK_B                   | SerDes PLL reference clock (and complement)                                                                       | -           |  |  |  |  |  |
| SDn_IMP_CAL_TX                                | Transmitter impedance calibration                                                                                 | -           |  |  |  |  |  |
| SDn_IMP_CAL_RX                                | Receiver impedance calibration                                                                                    | -           |  |  |  |  |  |
| SDn_PLL_TPA                                   | PLL test point analog                                                                                             | -           |  |  |  |  |  |
| SDn_PLL_TPD                                   | PLL test point digital                                                                                            | -           |  |  |  |  |  |

## 15.4.1 Detailed signal descriptions

For RGMII mode details, see the Hewlett-Packard reduced gigabit media-independent interface (RGMII) specification version 1.2a, dated 9/22/2000.

#### eTSEC external signals description

RMII mode details follow the RMII Consortium Specification, dated 3/20/1998. All other modes follow the IEEE 802.3 standard, 2000 Edition. Input signals not used are internally disabled. Except for TSEC*n*\_GTX\_CLK, output signals not used are driven low.

Table 15-2. eTSEC signals-detailed signal descriptions

| Signal           | I/O | Description                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                      |  |
|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| TSECn_COL        | I   | Collision input. The behavior of this signal is not specified while in full-duplex mode.                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                      |  |
|                  |     | This signal is not used in the following mode(s):                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                      |  |
|                  |     | RMII     RGMII                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                      |  |
|                  |     | State<br>meanin<br>g                                                                                                                                                                                                                                                                                                                                     | Asserted/Negated-In MII mode, this signal is asserted upon detection of a collision, and must remain asserted while the collision persists.                                                          |  |
|                  |     | Timing                                                                                                                                                                                                                                                                                                                                                   | Asserted/Negated-This signal is not required to transition synchronously with TSECn_TX_CLK or TSECn_RX_CLK.                                                                                          |  |
| TSECn_CRS        | I   | Carrier se                                                                                                                                                                                                                                                                                                                                               | ense input.                                                                                                                                                                                          |  |
|                  |     | This signa                                                                                                                                                                                                                                                                                                                                               | al is not used in the following mode(s):                                                                                                                                                             |  |
|                  |     | RMII     RGMII                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                      |  |
|                  |     | State<br>meanin<br>g                                                                                                                                                                                                                                                                                                                                     | Asserted/Negated-In MII mode, TSECn_CRS is asserted while the transmit or receive medium is not idle. In the event of a collision, TSECn_CRS must remain asserted for the duration of the collision. |  |
|                  |     | Timing                                                                                                                                                                                                                                                                                                                                                   | Asserted/Negated-This signal is not required to transition synchronously with TSECn_TX_CLK or TSECn_RX_CLK.                                                                                          |  |
| TSECn_GTX_CLK    | 0   | Gigabit tra                                                                                                                                                                                                                                                                                                                                              | ansmit clock. This signal is an output from the eTSEC into the PHY.                                                                                                                                  |  |
|                  |     | <ul> <li>In RGMII mode, TSECn_GTX_CLK becomes the transmit clock and provides timing reference during 1000Base-T (125 MHz), 100Base-T (25 MHz) and 10Base-T (2.5 MHz) transmissions.</li> <li>In RGMII mode, note that this signal feeds back the inverted transmit clock.</li> <li>This signal is driven low unless transmission is enabled.</li> </ul> |                                                                                                                                                                                                      |  |
| EC_GTX_CLK125    | I   | Gigabit transmit 125-MHz source. This signal must be generated externally with a crystal coscillator, or is sometimes provided by the PHY. EC_GTX_CLK125 is a 125-MHz input into eTSEC and is used to generate all 125-MHz related signals and clocks in the following mode(s):  • RGMII                                                                 |                                                                                                                                                                                                      |  |
|                  |     | This input is not used in these mode(s):                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                      |  |
|                  |     | MII     RMII     SGMII                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                      |  |
| TSEC1_GTX_CLK125 | I   | Gigabit reference clock. This signal can be configured to feed 125 MHz to eTSEC1 in RGMII mode.                                                                                                                                                                                                                                                          |                                                                                                                                                                                                      |  |
| EC_MDC           | 0   | Management data clock.                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                      |  |
|                  |     | This signal is a clock (typically 2.5 MHz) supplied by the MAC (IEEE set minimum period of 40 ns or a frequency of 2.5 MHz, but the device may be configured up to 12.5 MHz if supported by the PHY at that speed.) The frequency can be modified by writing to MIIMCFG[28:31] of the eTSEC1 controller.                                                 |                                                                                                                                                                                                      |  |

## Table 15-2. eTSEC signals-detailed signal descriptions (continued)

| Signal         | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                      |  |
|----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| EC_MDIO        | I/O | Management data input/output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                      |  |
|                |     | State<br>Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Asserted/Negated-EC_MDIO is a bidirectional signal to input PHY-supplied status during management read cycles and output control during MII management write cycles. Addressed using eTSEC1 memory-mapped registers.                                                                 |  |
|                |     | Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Asserted/Negated-This signal is required to be synchronous with the EC_MDC signal.                                                                                                                                                                                                   |  |
| TSECn_RX_CLK   | I   | Receive clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                      |  |
|                |     | <ul> <li>In MII, RGMII mode, the receive clock TSECn_RX_CLK is a continuous clock (2.5, 25, or 125 MHz) that provides a timing reference for TSECn_RX_DV, TSECn_RXD, and TSECn_RX_ER.</li> <li>In RMII mode this clock is not used for the receive clock, as RMII uses a shared reference clock.</li> </ul>                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                      |  |
| TSECn_RX_DV    | I   | Receive o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ata valid.                                                                                                                                                                                                                                                                           |  |
|                |     | <ul> <li>In MII mode, if TSECn_RX_DV is asserted, the PHY is indicating that valid data is present on the MII interface.</li> <li>In RMII mode the PHY asserts TSECn_RX_DV (CRS_DV) when the receive medium is non-idle. This signal asserts asynchronously with respect to the RMII reference clock, but negates synchronously to indicate loss of carrier.</li> <li>In RGMII mode, TSECn_RX_DV becomes RX_CTL. The RX_DV and RX_ERR are received on this signal on the rising and falling edges of TSECn_RX_CLK.</li> </ul>                                                       |                                                                                                                                                                                                                                                                                      |  |
| TSECn_RXD[3:0] | I   | Receive c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ata in.                                                                                                                                                                                                                                                                              |  |
|                |     | <ul> <li>In MII mode, TSECn_RXD[3:0] represents a nibble of data to be transferred from the PHY to the MAC when TSECn_RX_DV is asserted. A completely-formed SFD must be passed across the MII. While TSECn_RX_DV is not asserted, TSECn_RXD has no meaning.</li> <li>In RMII mode, TSECn_RXD[1:0] represents RXD[1:0], which is considered valid when TSECn_RX_DV (CRS_DV) is asserted, or invalid otherwise.</li> <li>In RGMII mode, data bits 3-0 are received on the rising edge of TSECn_RX_CLK and data bits 7-4 are received on the falling edge of TSECn_RX_CLK.</li> </ul> |                                                                                                                                                                                                                                                                                      |  |
| TSECn_RX_ER    | I   | Receive e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | rror.                                                                                                                                                                                                                                                                                |  |
|                |     | This signal is not used in the following mode(s):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                      |  |
|                |     | • RG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MII                                                                                                                                                                                                                                                                                  |  |
|                |     | State<br>Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <ul> <li>Asserted/Negated-</li> <li>In MII mode, if TSECn_RX_ER and TSECn_RX_DV are asserted, the PHY has detected an error in the current frame.</li> <li>In RMII mode, if TSECn_RX_ER and TSECn_RX_DV are asserted, the PHY has detected an error in the current frame.</li> </ul> |  |
| TSECn_TX_CLK   | I   | Transmit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | clock in.                                                                                                                                                                                                                                                                            |  |
|                |     | timi<br>• In F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | III mode, TSECn_TX_CLK is a continuous clock (2.5 or 25 MHz) that provides a ng reference for the TSECn_TX_EN, TSECn_TXD, and TSECn_TX_ER signals. IMII mode this signal is the reference clock shared between transmit and receive, and upplied by the PHY.                         |  |
|                |     | This signa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | al is not used in the following mode(s):                                                                                                                                                                                                                                             |  |
|                |     | • RGI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | MII                                                                                                                                                                                                                                                                                  |  |

Table 15-2. eTSEC signals-detailed signal descriptions (continued)

| Signal                   | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| TSECn_TXD[3:0]           | 0   | Transmit data out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                          |     | <ul> <li>In MII mode, TSECn_TXD[3:0] represent a nibble of data to be sent from the MAC to the PHY when TSECn_TX_EN is asserted and have no meaning while TSECn_TX_EN is negated.</li> <li>In RMII mode TSECn_TXD[1:0] represents TXD[1:0], which is valid data sent to the PHY when TSECn_TX_EN is asserted, or undefined otherwise.</li> <li>In RGMII mode, data bits 3-0 are transmitted on the rising edge of TSECn_GTX_CLK, and data bits 7-4 are transmitted on the falling edge of TSECn_GTX_CLK.</li> <li>Note that some of these signals are also used during reset to configure the eTSEC interface</li> </ul> |  |
| TOFO TY FN               |     | mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| TSECn_TX_EN              | 0   | Transmit data valid  In MII mode, if TSECn_TX_EN is asserted, the MAC is indicating that valid data is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                          |     | <ul> <li>present on the MII's TSECn_TXD signals.</li> <li>In RMII mode, if TSECn_TX_EN is asserted, the MAC is indicating that valid data is present on the MII's TSECn_TXD signals.</li> <li>In RGMII mode, TSECn_TX_EN becomes TX_CTL. TX_EN and TX_ERR are asserted on this signal on rising and falling edges of the TSECn_GTX_CLK, respectively.</li> </ul>                                                                                                                                                                                                                                                         |  |
| TSECn_TX_ER              | 0   | Transmit error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                          |     | <ul> <li>In MII mode, assertion of TSECn_TX_ER for one or more clock cycles while<br/>TSECn_TX_EN is asserted causes the PHY to transmit one or more illegal symbols.<br/>Asserting TSECn_TX_ER has no effect while operating at 10 Mbps or while<br/>TSECn_TX_EN is negated. This signal transitions synchronously with respect to<br/>TSECn_TX_CLK.</li> </ul>                                                                                                                                                                                                                                                         |  |
|                          |     | This signal is not used in the following mode(s) and is driven low:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                          |     | RMII     RGMII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| TSEC_1588_ CLK_IN        | I   | 1588 clock in. External high precision timer reference clock input (chip external input pin).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| TSEC_1588_<br>CLK_OUT    | 0   | 1588 clock out. Phase aligned timer clock divider output (chip external output pin).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| TSEC_1588_<br>TRIG_IN1   | I   | 1588 trigger in 1. External timer trigger input 1. This is an asynchronous general purpose input (chip external input pin).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| TSEC_1588_<br>TRIG_IN2   | I   | 1588 trigger in 2. External timer trigger input 2. This is an asynchronous general purpose input (chip external input pin).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| TSEC_<br>1588_PULSE_OUT1 | 0   | 1588 pulse out 1. Timer pulse per period 1. It is phase aligned with 1588 timer clock (chip external output pin)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| TSEC_1588_<br>PULSE_OUT2 | 0   | 1588 pulse out 2. Timer pulse per period 2. It is phase aligned with 1588 timer clock (chip external output pin)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| TSEC_1588_<br>ALARM_OUT1 | 0   | 1588 timer alarm 1. Timer current time is equal to or greater than alarm time comparator register. User reprograms the TMR_ALARMn_H/L register to deactivate this output (chip external output pin)                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| TSEC_1588_<br>ALARM_OUT2 | 0   | 1588 timer alarm 2. Timer current time is equal to or greater than alarm time comparator register. User reprograms the TMR_ALARMn_H/L register to deactivate this output (chip external output pin)                                                                                                                                                                                                                                                                                                                                                                                                                      |  |

# 15.5 eTSEC memory map/register definition

#### 15.5.1 Top-level module memory map

Each of the eTSECs is allocated 12 Kbytes of memory-mapped space-one 4 Kbyte region per group and a separate 4 Kbyte region for MDIO.

The 4 Kbyte group memory-mapped space for each eTSEC is divided as indicated in the following table.

| Address offset | Function                                |
|----------------|-----------------------------------------|
| 0x000-0x0FF    | eTSEC general control/status registers  |
| 0x100-0x2FF    | eTSEC transmit control/status registers |
| 0x300-0x4FF    | eTSEC receive control/status registers  |
| 0x500-0x5FF    | MAC registers                           |
| 0x600-0x7FF    | RMON MIB registers                      |
| 0x800-0x8FF    | Hash table registers                    |
| 0x900-0xAFF    | Reserved                                |
| 0xB00-0xBFF    | DMA system registers                    |
| 0xC00-0xC3F    | Lossless flow control registers         |
| 0xC40-0xDFF    | Reserved                                |
| 0xE00-0xEAF    | 1588 Hardware assist                    |
| 0xEB0-0xEFF    | Interrupt steering and coalescing       |
| 0xF00-0xFFF    | Reserved                                |

Table 15-3. Group memory map summary

The eTSEC memory mapped registers are accessed by reading and writing to an address comprised of the base address (specified in CCSRBAR as defined in Memory Map) plus the block base address, plus the offset of the specific register to be accessed. Note that all memory-mapped registers must only be accessed as 32-bit quantities.

The memory map table lists the offset, name, and a cross-reference to the complete description of each register. The offsets to the memory map table are applicable to each eTSEC. Block base addresses are as follows:

- eTSEC1 MDIO starts at 0x2\_4000 address offset
- eTSEC2 MDIO starts at 0x2\_5000 address offset
- eTSEC3 MDIO starts at 0x2\_6000 address offset

#### eTSEC memory map/register definition

- eTSEC1 group 0 starts at 0xB\_0000 address offset
- eTSEC2 group 0 starts at 0xB\_1000 address offset
- eTSEC3 group 0 starts at 0xB\_2000 address offset
- eTSEC1 group 1 starts at 0xB\_4000 address offset
- eTSEC2 group 1 starts at 0xB\_5000 address offset
- eTSEC3 group 1 starts at 0xB\_6000 address offset

Unless otherwise noted, each register has one instance with multiple aliased addresses (one per group). Some registers have one instance per group and are marked as such with an 'n' suffix in the name.

This section provides a detailed description of all the eTSEC registers. Because all of the eTSEC registers are 32 bits wide, only 32-bit register accesses are supported.

Note that all, except the unique per-group (xG g) registers, have address aliases in all groups of the form a + 0x4000x g. Only the group 0 register offsets are listed for the shared registers.

#### NOTE

Registers denoted \* are new to the TSEC and not supported by PowerQUICC III TSECs.

#### eTSEC memory map

| Offset address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0000               | Controller ID register * (eTSEC1_TSEC_ID)        | 32                 | R      | 0124_0200h  | 15.5.2/931       |
| B_0004               | Controller ID register * (eTSEC1_TSEC_ID2)       | 32                 | R      | See section | 15.5.3/932       |
| B_0010               | Group Interrupt event register (eTSEC1_IEVENTG0) | 32                 | w1c    | 0000_0000h  | 15.5.4/933       |
| B_0014               | Group Interrupt mask register (eTSEC1_IMASKG0)   | 32                 | R/W    | 0000_0000h  | 15.5.5/939       |
| B_0018               | Error disabled register (eTSEC1_EDIS)            | 32                 | R/W    | 0000_0000h  | 15.5.6/941       |
| B_001C               | Group Error mapping register (eTSEC1_EMAPG)      | 32                 | R/W    | 0000_0000h  | 15.5.7/943       |
| B_0020               | Ethernet control register (eTSEC1_ECNTRL)        | 32                 | R/W    | 0000_0000h  | 15.5.8/945       |
| B_0028               | Pause time value register (eTSEC1_PTV)           | 32                 | R/W    | 0000_0000h  | 15.5.9/949       |
| B_002C               | DMA control register (eTSEC1_DMACTRL)            | 32                 | R/W    | 0000_0000h  | 15.5.10/<br>950  |
| B_0030               | TBI PHY address register (eTSEC1_TBIPA)          | 32                 | R/W    | 0000_0000h  | 15.5.11/<br>952  |
| B_0100               | Transmit control register (eTSEC1_TCTRL)         | 32                 | R/W    | 0000_0000h  | 15.5.12/<br>952  |
| B_0104               | Transmit status register (eTSEC1_TSTAT0)         | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956  |
| B_0108               | Default VLAN control word * (eTSEC1_DFVLAN)      | 32                 | R/W    | 8100_0000h  | 15.5.14/<br>960  |

| Offset<br>address<br>(hex) | Register name                                           | Width (in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------|-----------------|--------|-------------|------------------|
| B_0110                     | Transmit interrupt coalescing register (eTSEC1_TXIC)    | 32              | R/W    | 0000_0000h  | 15.5.15/<br>961  |
| B_0114                     | Transmit queue control register * (eTSEC1_TQUEUE)       | 32              | R/W    | 0000_8000h  | 15.5.16/<br>962  |
| B_0140                     | TxBD Rings 0-3 round-robin weightings * (eTSEC1_TR03WT) | 32              | R/W    | 0000_0000h  | 15.5.17/<br>963  |
| B_0144                     | TxBD Rings 4-7 round-robin weightings * (eTSEC1_TR47WT) | 32              | R/W    | 0000_0000h  | 15.5.18/<br>964  |
| B_0180                     | Tx data buffer pointer high bits * (eTSEC1_TBDBPH)      | 32              | R/W    | 0000_0000h  | 15.5.19/<br>965  |
| B_0184                     | TxBD pointer for ring n (eTSEC1_TBPTR0)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_018C                     | TxBD pointer for ring n (eTSEC1_TBPTR1)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_0194                     | TxBD pointer for ring n (eTSEC1_TBPTR2)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_019C                     | TxBD pointer for ring n (eTSEC1_TBPTR3)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_01A4                     | TxBD pointer for ring n (eTSEC1_TBPTR4)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_01AC                     | TxBD pointer for ring n (eTSEC1_TBPTR5)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_01B4                     | TxBD pointer for ring n (eTSEC1_TBPTR6)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_01BC                     | TxBD pointer for ring n (eTSEC1_TBPTR7)                 | 32              | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_0200                     | TxBD base address high bits * (eTSEC1_TBASEH)           | 32              | R/W    | 0000_0000h  | 15.5.21/<br>966  |
| B_0204                     | TxBD base address of ring n (eTSEC1_TBASE0)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_020C                     | TxBD base address of ring n (eTSEC1_TBASE1)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_0214                     | TxBD base address of ring n (eTSEC1_TBASE2)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_021C                     | TxBD base address of ring n (eTSEC1_TBASE3)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_0224                     | TxBD base address of ring n (eTSEC1_TBASE4)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_022C                     | TxBD base address of ring n (eTSEC1_TBASE5)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_0234                     | TxBD base address of ring n (eTSEC1_TBASE6)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_023C                     | TxBD base address of ring n (eTSEC1_TBASE7)             | 32              | R/W    | 0000_0000h  | 15.5.22/<br>967  |

| Offset address (hex) | Register name                                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0280               | Tx time stamp identification tag [set n] * (eTSEC1_TMR_TXTS1_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_0284               | Tx time stamp identification tag [set n] * (eTSEC1_TMR_TXTS2_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_02C0               | Tx time stamp high [set n] * (eTSEC1_TMR_TXTS1_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_02C4               | Tx time stamp low [set n] * (eTSEC1_TMR_TXTS1_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_02C8               | Tx time stamp high [set n] * (eTSEC1_TMR_TXTS2_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_02CC               | Tx time stamp low [set n] * (eTSEC1_TMR_TXTS2_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_0300               | Receive control register (eTSEC1_RCTRL)                          | 32                 | R/W    | 0000_0000h  | 15.5.26/<br>969  |
| B_0304               | Receive status register (eTSEC1_RSTAT0)                          | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972  |
| B_0310               | Receive interrupt coalescing register (eTSEC1_RXIC)              | 32                 | R/W    | 0000_0000h  | 15.5.28/<br>975  |
| B_0314               | Receive queue control register * (eTSEC1_RQUEUE)                 | 32                 | R/W    | 0080_0080h  | 15.5.29/<br>976  |
| B_0318               | Ring mapping register n * (eTSEC1_RIR0)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_031C               | Ring mapping register n * (eTSEC1_RIR1)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_0320               | Ring mapping register n * (eTSEC1_RIR2)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_0324               | Ring mapping register n * (eTSEC1_RIR3)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_0330               | Receive bit field extract control register * (eTSEC1_RBIFX)      | 32                 | R/W    | 0000_0000h  | 15.5.31/<br>979  |
| B_0334               | Receive queue filing table address register * (eTSEC1_RQFAR)     | 32                 | R/W    | 0000_0000h  | 15.5.32/<br>981  |
| B_0338               | Receive queue filer table control register * (eTSEC1_RQFCR)      | 32                 | R/W    | 0000_0000h  | 15.5.33/<br>982  |
| B_033C               | Receive queue filing table property register * (eTSEC1_RQFPR)    | 32                 | R/W    | 0000_0000h  | 15.5.34/<br>984  |
| B_0340               | Maximum receive buffer length register (eTSEC1_MRBLR)            | 32                 | R/W    | 0000_0000h  | 15.5.35/<br>988  |
| B_0350               | Receive packet wakeup timer register (eTSEC1_RPWT)               | 32                 | R/W    | 0000_0000h  | 15.5.36/<br>989  |
| B_0380               | Rx data buffer pointer high bits * (eTSEC1_RBDBPH)               | 32                 | R/W    | 0000_0000h  | 15.5.37/<br>990  |
| B_0384               | RxBD pointer for ring n (eTSEC1_RBPTR0)                          | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |

| Offset address (hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_038C               | RxBD pointer for ring n (eTSEC1_RBPTR1)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_0394               | RxBD pointer for ring n (eTSEC1_RBPTR2)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_039C               | RxBD pointer for ring n (eTSEC1_RBPTR3)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_03A4               | RxBD pointer for ring n (eTSEC1_RBPTR4)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_03AC               | RxBD pointer for ring n (eTSEC1_RBPTR5)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_03B4               | RxBD pointer for ring n (eTSEC1_RBPTR6)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_03BC               | RxBD pointer for ring n (eTSEC1_RBPTR7)                 | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_0400               | RxBD base address high bits * (eTSEC1_RBASEH)           | 32                 | R/W    | 0000_0000h  | 15.5.39/<br>991  |
| B_0404               | RxBD base address of ring n (eTSEC1_RBASE0)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_040C               | RxBD base address of ring n (eTSEC1_RBASE1)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_0414               | RxBD base address of ring n (eTSEC1_RBASE2)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_041C               | RxBD base address of ring n (eTSEC1_RBASE3)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_0424               | RxBD base address of ring n (eTSEC1_RBASE4)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_042C               | RxBD base address of ring n (eTSEC1_RBASE5)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_0434               | RxBD base address of ring n (eTSEC1_RBASE6)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_043C               | RxBD base address of ring n (eTSEC1_RBASE7)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_04C0               | Rx timer time stamp register high * (eTSEC1_TMR_RXTS_H) | 32                 | R      | 0000_0000h  | 15.5.41/<br>992  |
| B_04C4               | Rx timer time stamp register low * (eTSEC1_TMR_RXTS_L)  | 32                 | R      | 0000_0000h  | 15.5.42/<br>993  |
| B_0500               | MAC configuration register 1 (eTSEC1_MACCFG1)           | 32                 | R/W    | 0000_0000h  | 15.5.43/<br>994  |
| B_0504               | MAC configuration register 2 (eTSEC1_MACCFG2)           | 32                 | R/W    | 0000_7000h  | 15.5.44/<br>996  |
| B_0508               | Interpacket/interframe gap register (eTSEC1_IPGIFG)     | 32                 | R/W    | 4060_5060h  | 15.5.45/<br>998  |
| B_050C               | Half-duplex control (eTSEC1_HAFDUP)                     | 32                 | R/W    | 00A1_F037h  | 15.5.46/<br>1000 |

| Offset<br>address<br>(hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0510                     | Maximum frame length (eTSEC1_MAXFRM)                    | 32                 | R/W    | 0000_0600h  | 15.5.47/<br>1001 |
| B_053C                     | Interface status (eTSEC1_IFSTAT)                        | 32                 | R      | 0000_0000h  | 15.5.48/<br>1001 |
| B_0540                     | MAC station address register 1 (eTSEC1_MACSTNADDR1)     | 32                 | R/W    | 0000_0000h  | 15.5.49/<br>1003 |
| B_0544                     | MAC station address register 2 (eTSEC1_MACSTNADDR2)     | 32                 | R/W    | 0000_0000h  | 15.5.50/<br>1003 |
| B_0548                     | MAC exact match address n, part 1 * (eTSEC1_MAC01ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_054C                     | MAC exact match address n, part 2 * (eTSEC1_MAC01ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0550                     | MAC exact match address n, part 1 * (eTSEC1_MAC02ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_0554                     | MAC exact match address n, part 2 * (eTSEC1_MAC02ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0558                     | MAC exact match address n, part 1 * (eTSEC1_MAC03ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_055C                     | MAC exact match address n, part 2 * (eTSEC1_MAC03ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0560                     | MAC exact match address n, part 1 * (eTSEC1_MAC04ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_0564                     | MAC exact match address n, part 2 * (eTSEC1_MAC04ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0568                     | MAC exact match address n, part 1 * (eTSEC1_MAC05ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_056C                     | MAC exact match address n, part 2 * (eTSEC1_MAC05ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0570                     | MAC exact match address n, part 1 * (eTSEC1_MAC06ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_0574                     | MAC exact match address n, part 2 * (eTSEC1_MAC06ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0578                     | MAC exact match address n, part 1 * (eTSEC1_MAC07ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_057C                     | MAC exact match address n, part 2 * (eTSEC1_MAC07ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0580                     | MAC exact match address n, part 1 * (eTSEC1_MAC08ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_0584                     | MAC exact match address n, part 2 * (eTSEC1_MAC08ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0588                     | MAC exact match address n, part 1 * (eTSEC1_MAC09ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_058C                     | MAC exact match address n, part 2 * (eTSEC1_MAC09ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |

| Offset<br>address<br>(hex) | Register name                                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0590                     | MAC exact match address n, part 1 * (eTSEC1_MAC10ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_0594                     | MAC exact match address n, part 2 * (eTSEC1_MAC10ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0598                     | MAC exact match address n, part 1 * (eTSEC1_MAC11ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_059C                     | MAC exact match address n, part 2 * (eTSEC1_MAC11ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_05A0                     | MAC exact match address n, part 1 * (eTSEC1_MAC12ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_05A4                     | MAC exact match address n, part 2 * (eTSEC1_MAC12ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_05A8                     | MAC exact match address n, part 1 * (eTSEC1_MAC13ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_05AC                     | MAC exact match address n, part 2 * (eTSEC1_MAC13ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_05B0                     | MAC exact match address n, part 1 * (eTSEC1_MAC14ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_05B4                     | MAC exact match address n, part 2 * (eTSEC1_MAC14ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_05B8                     | MAC exact match address n, part 1 * (eTSEC1_MAC15ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_05BC                     | MAC exact match address n, part 2 * (eTSEC1_MAC15ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_0680                     | Transmit and receive 64-byte frame counter (eTSEC1_TR64)                     | 32                 | R/W    | 0000_0000h  | 15.5.53/<br>1006 |
| B_0684                     | Transmit and receive 65- to 127-byte frame counter (eTSEC1_TR127)            | 32                 | R/W    | 0000_0000h  | 15.5.54/<br>1006 |
| B_0688                     | Transmit and receive 128- to 255-byte frame counter (eTSEC1_TR255)           | 32                 | R/W    | 0000_0000h  | 15.5.55/<br>1007 |
| B_068C                     | Transmit and receive 256- to 511-byte frame counter (eTSEC1_TR511)           | 32                 | R/W    | 0000_0000h  | 15.5.56/<br>1007 |
| B_0690                     | Transmit and receive 512- to 1023-byte frame counter (eTSEC1_TR1K)           | 32                 | R/W    | 0000_0000h  | 15.5.57/<br>1008 |
| B_0694                     | Transmit and receive 1024- to 1518-byte frame counter (eTSEC1_TRMAX)         | 32                 | R/W    | 0000_0000h  | 15.5.58/<br>1008 |
| B_0698                     | Transmit and receive 1519- to 1522-byte good VLAN frame count (eTSEC1_TRMGV) | 32                 | R/W    | 0000_0000h  | 15.5.59/<br>1009 |
| B_069C                     | Receive byte counter (eTSEC1_RBYT)                                           | 32                 | R/W    | 0000_0000h  | 15.5.60/<br>1009 |
| B_06A0                     | Receive packet counter (eTSEC1_RPKT)                                         | 32                 | R/W    | 0000_0000h  | 15.5.61/<br>1010 |
| B_06A4                     | Receive FCS error counter (eTSEC1_RFCS)                                      | 32                 | R/W    | 0000_0000h  | 15.5.62/<br>1010 |

| Offset<br>address<br>(hex) | Register name                                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_06A8                     | Receive multicast packet counter (eTSEC1_RMCA)           | 32                 | R/W    | 0000_0000h  | 15.5.63/<br>1011 |
| B_06AC                     | Receive broadcast packet counter (eTSEC1_RBCA)           | 32                 | R/W    | 0000_0000h  | 15.5.64/<br>1011 |
| B_06B0                     | Receive control frame packet counter (eTSEC1_RXCF)       | 32                 | R/W    | 0000_0000h  | 15.5.65/<br>1012 |
| B_06B4                     | Receive PAUSE frame packet counter (eTSEC1_RXPF)         | 32                 | R/W    | 0000_0000h  | 15.5.66/<br>1012 |
| B_06B8                     | Receive unknown OP code counter (eTSEC1_RXUO)            | 32                 | R/W    | 0000_0000h  | 15.5.67/<br>1013 |
| B_06BC                     | Receive alignment error counter (eTSEC1_RALN)            | 32                 | R/W    | 0000_0000h  | 15.5.68/<br>1013 |
| B_06C0                     | Receive frame length error counter (eTSEC1_RFLR)         | 32                 | R/W    | 0000_0000h  | 15.5.69/<br>1014 |
| B_06C4                     | Receive code error counter (eTSEC1_RCDE)                 | 32                 | R/W    | 0000_0000h  | 15.5.70/<br>1014 |
| B_06C8                     | Receive carrier sense error counter (eTSEC1_RCSE)        | 32                 | R/W    | 0000_0000h  | 15.5.71/<br>1015 |
| B_06CC                     | Receive undersize packet counter (eTSEC1_RUND)           | 32                 | R/W    | 0000_0000h  | 15.5.72/<br>1015 |
| B_06D0                     | Receive oversize packet counter (eTSEC1_ROVR)            | 32                 | R/W    | 0000_0000h  | 15.5.73/<br>1016 |
| B_06D4                     | Receive fragments counter (eTSEC1_RFRG)                  | 32                 | R/W    | 0000_0000h  | 15.5.74/<br>1016 |
| B_06D8                     | Receive jabber counter (eTSEC1_RJBR)                     | 32                 | R/W    | 0000_0000h  | 15.5.75/<br>1017 |
| B_06DC                     | Receive drop counter (eTSEC1_RDRP)                       | 32                 | R/W    | 0000_0000h  | 15.5.76/<br>1017 |
| B_06E0                     | Transmit byte counter (eTSEC1_TBYT)                      | 32                 | R/W    | 0000_0000h  | 15.5.77/<br>1018 |
| B_06E4                     | Transmit packet counter (eTSEC1_TPKT)                    | 32                 | R/W    | 0000_0000h  | 15.5.78/<br>1018 |
| B_06E8                     | Transmit multicast packet counter (eTSEC1_TMCA)          | 32                 | R/W    | 0000_0000h  | 15.5.79/<br>1019 |
| B_06EC                     | Transmit broadcast packet counter (eTSEC1_TBCA)          | 32                 | R/W    | 0000_0000h  | 15.5.80/<br>1019 |
| B_06F0                     | Transmit PAUSE control frame counter (eTSEC1_TXPF)       | 32                 | R/W    | 0000_0000h  | 15.5.81/<br>1020 |
| B_06F4                     | Transmit deferral packet counter (eTSEC1_TDFR)           | 32                 | R/W    | 0000_0000h  | 15.5.82/<br>1020 |
| B_06F8                     | Transmit excessive deferral packet counter (eTSEC1_TEDF) | 32                 | R/W    | 0000_0000h  | 15.5.83/<br>1021 |
| B_06FC                     | Transmit single collision packet counter (eTSEC1_TSCL)   | 32                 | R/W    | 0000_0000h  | 15.5.84/<br>1021 |

| Offset<br>address<br>(hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|-----------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_0700                     | Transmit multiple collision packet counter (eTSEC1_TMCL)  | 32                 | R/W    | 0000_0000h  | 15.5.85/<br>1022  |
| B_0704                     | Transmit late collision packet counter (eTSEC1_TLCL)      | 32                 | R/W    | 0000_0000h  | 15.5.86/<br>1022  |
| B_0708                     | Transmit excessive collision packet counter (eTSEC1_TXCL) | 32                 | R/W    | 0000_0000h  | 15.5.87/<br>1023  |
| B_070C                     | Transmit total collision counter (eTSEC1_TNCL)            | 32                 | R/W    | 0000_0000h  | 15.5.88/<br>1023  |
| B_0714                     | Transmit drop frame counter (eTSEC1_TDRP)                 | 32                 | R/W    | 0000_0000h  | 15.5.89/<br>1024  |
| B_0718                     | Transmit jabber frame counter (eTSEC1_TJBR)               | 32                 | R/W    | 0000_0000h  | 15.5.90/<br>1024  |
| B_071C                     | Transmit FCS error counter (eTSEC1_TFCS)                  | 32                 | R/W    | 0000_0000h  | 15.5.91/<br>1025  |
| B_0720                     | Transmit control frame counter (eTSEC1_TXCF)              | 32                 | R/W    | 0000_0000h  | 15.5.92/<br>1025  |
| B_0724                     | Transmit oversize frame counter (eTSEC1_TOVR)             | 32                 | R/W    | 0000_0000h  | 15.5.93/<br>1026  |
| B_0728                     | Transmit undersize frame counter (eTSEC1_TUND)            | 32                 | R/W    | 0000_0000h  | 15.5.94/<br>1026  |
| B_072C                     | Transmit fragments frame counter (eTSEC1_TFRG)            | 32                 | R/W    | 0000_0000h  | 15.5.95/<br>1027  |
| B_0730                     | Carry register one (eTSEC1_CAR1)                          | 32                 | R/W    | 0000_0000h  | 15.5.96/<br>1028  |
| B_0734                     | Carry register two (eTSEC1_CAR2)                          | 32                 | R/W    | 0000_0000h  | 15.5.97/<br>1030  |
| B_0738                     | Carry register one mask register (eTSEC1_CAM1)            | 32                 | R/W    | FE03_FFFFh  | 15.5.98/<br>1032  |
| B_073C                     | Carry register two mask register (eTSEC1_CAM2)            | 32                 | R/W    | 000F_FFFDh  | 15.5.99/<br>1034  |
| B_0740                     | Receive filer rejected packet counter * (eTSEC1_RREJ)     | 32                 | R/W    | 0000_0000h  | 15.5.100/<br>1035 |
| B_0800                     | Individual/group address register n (eTSEC1_IGADDR0)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_0804                     | Individual/group address register n (eTSEC1_IGADDR1)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_0808                     | Individual/group address register n (eTSEC1_IGADDR2)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_080C                     | Individual/group address register n (eTSEC1_IGADDR3)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_0810                     | Individual/group address register n (eTSEC1_IGADDR4)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_0814                     | Individual/group address register n (eTSEC1_IGADDR5)      | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |

| Offset<br>address<br>(hex) | Register name                                                          | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|------------------------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_0818                     | Individual/group address register n (eTSEC1_IGADDR6)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_081C                     | Individual/group address register n (eTSEC1_IGADDR7)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_0880                     | Group address register n (eTSEC1_GADDR0)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0884                     | Group address register n (eTSEC1_GADDR1)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0888                     | Group address register n (eTSEC1_GADDR2)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_088C                     | Group address register n (eTSEC1_GADDR3)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0890                     | Group address register n (eTSEC1_GADDR4)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0894                     | Group address register n (eTSEC1_GADDR5)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0898                     | Group address register n (eTSEC1_GADDR6)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_089C                     | Group address register n (eTSEC1_GADDR7)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_0BF8                     | Attribute register (eTSEC1_ATTR)                                       | 32                 | R/W    | 0000_0000h  | 15.5.103/<br>1037 |
| B_0BFC                     | Attribute extract length and extract index register * (eTSEC1_ATTRELI) | 32                 | R/W    | 0000_0000h  | 15.5.104/<br>1039 |
| B_0C00                     | Receive Queue Parameters register n * (eTSEC1_RQPRM0)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C04                     | Receive Queue Parameters register n * (eTSEC1_RQPRM1)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C08                     | Receive Queue Parameters register n * (eTSEC1_RQPRM2)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C0C                     | Receive Queue Parameters register n * (eTSEC1_RQPRM3)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C10                     | Receive Queue Parameters register n * (eTSEC1_RQPRM4)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C14                     | Receive Queue Parameters register n * (eTSEC1_RQPRM5)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C18                     | Receive Queue Parameters register n * (eTSEC1_RQPRM6)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C1C                     | Receive Queue Parameters register n * (eTSEC1_RQPRM7)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_0C44                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR0)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C4C                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR1)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |

| Offset<br>address<br>(hex) | Register name                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_0C54                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR2) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C5C                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR3) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C64                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR4) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C6C                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR5) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C74                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR6) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0C7C                     | Last Free RxBD pointer for ring n * (eTSEC1_RFBPTR7) | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_0EB0                     | Interrupt steering register group n (eTSEC1_ISRG0)   | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |
| B_0EB4                     | Interrupt steering register group n (eTSEC1_ISRG1)   | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |
| B_0ED0                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC0)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0ED4                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC1)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0ED8                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC2)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0EDC                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC3)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0EE0                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC4)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0EE4                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC5)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0EE8                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC6)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0EEC                     | Ring n Rx interrupt coalescing (eTSEC1_RXIC7)        | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_0F10                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC0)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F14                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC1)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F18                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC2)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F1C                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC3)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F20                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC4)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F24                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC5)        | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |

| Offset<br>address<br>(hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|---------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_0F28                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC6)           | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_0F2C                     | Ring n Tx interrupt coalescing (eTSEC1_TXIC7)           | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_4010                     | Group Interrupt event register (eTSEC1_IEVENTG1)        | 32                 | w1c    | 0000_0000h  | 15.5.4/933        |
| B_4014                     | Group Interrupt mask register (eTSEC1_IMASKG1)          | 32                 | R/W    | 0000_0000h  | 15.5.5/939        |
| B_4104                     | Transmit status register (eTSEC1_TSTAT1)                | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956   |
| B_4304                     | Receive status register (eTSEC1_RSTAT1)                 | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972   |
| B_1000                     | Controller ID register * (eTSEC2_TSEC_ID)               | 32                 | R      | 0124_0200h  | 15.5.2/931        |
| B_1004                     | Controller ID register * (eTSEC2_TSEC_ID2)              | 32                 | R      | See section | 15.5.3/932        |
| B_1010                     | Group Interrupt event register (eTSEC2_IEVENTG0)        | 32                 | w1c    | 0000_0000h  | 15.5.4/933        |
| B_1014                     | Group Interrupt mask register (eTSEC2_IMASKG0)          | 32                 | R/W    | 0000_0000h  | 15.5.5/939        |
| B_1018                     | Error disabled register (eTSEC2_EDIS)                   | 32                 | R/W    | 0000_0000h  | 15.5.6/941        |
| B_101C                     | Group Error mapping register (eTSEC2_EMAPG)             | 32                 | R/W    | 0000_0000h  | 15.5.7/943        |
| B_1020                     | Ethernet control register (eTSEC2_ECNTRL)               | 32                 | R/W    | 0000_0000h  | 15.5.8/945        |
| B_1028                     | Pause time value register (eTSEC2_PTV)                  | 32                 | R/W    | 0000_0000h  | 15.5.9/949        |
| B_102C                     | DMA control register (eTSEC2_DMACTRL)                   | 32                 | R/W    | 0000_0000h  | 15.5.10/<br>950   |
| B_1030                     | TBI PHY address register (eTSEC2_TBIPA)                 | 32                 | R/W    | 0000_0000h  | 15.5.11/<br>952   |
| B_1100                     | Transmit control register (eTSEC2_TCTRL)                | 32                 | R/W    | 0000_0000h  | 15.5.12/<br>952   |
| B_1104                     | Transmit status register (eTSEC2_TSTAT0)                | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956   |
| B_1108                     | Default VLAN control word * (eTSEC2_DFVLAN)             | 32                 | R/W    | 8100_0000h  | 15.5.14/<br>960   |
| B_1110                     | Transmit interrupt coalescing register (eTSEC2_TXIC)    | 32                 | R/W    | 0000_0000h  | 15.5.15/<br>961   |
| B_1114                     | Transmit queue control register * (eTSEC2_TQUEUE)       | 32                 | R/W    | 0000_8000h  | 15.5.16/<br>962   |
| B_1140                     | TxBD Rings 0-3 round-robin weightings * (eTSEC2_TR03WT) | 32                 | R/W    | 0000_0000h  | 15.5.17/<br>963   |
| B_1144                     | TxBD Rings 4-7 round-robin weightings * (eTSEC2_TR47WT) | 32                 | R/W    | 0000_0000h  | 15.5.18/<br>964   |
| B_1180                     | Tx data buffer pointer high bits * (eTSEC2_TBDBPH)      | 32                 | R/W    | 0000_0000h  | 15.5.19/<br>965   |
| B_1184                     | TxBD pointer for ring n (eTSEC2_TBPTR0)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966   |
| B_118C                     | TxBD pointer for ring n (eTSEC2_TBPTR1)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966   |

| Offset<br>address<br>(hex) | Register name                                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_1194                     | TxBD pointer for ring n (eTSEC2_TBPTR2)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_119C                     | TxBD pointer for ring n (eTSEC2_TBPTR3)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_11A4                     | TxBD pointer for ring n (eTSEC2_TBPTR4)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_11AC                     | TxBD pointer for ring n (eTSEC2_TBPTR5)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_11B4                     | TxBD pointer for ring n (eTSEC2_TBPTR6)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_11BC                     | TxBD pointer for ring n (eTSEC2_TBPTR7)                          | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_1200                     | TxBD base address high bits * (eTSEC2_TBASEH)                    | 32                 | R/W    | 0000_0000h  | 15.5.21/<br>966  |
| B_1204                     | TxBD base address of ring n (eTSEC2_TBASE0)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_120C                     | TxBD base address of ring n (eTSEC2_TBASE1)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_1214                     | TxBD base address of ring n (eTSEC2_TBASE2)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_121C                     | TxBD base address of ring n (eTSEC2_TBASE3)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_1224                     | TxBD base address of ring n (eTSEC2_TBASE4)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_122C                     | TxBD base address of ring n (eTSEC2_TBASE5)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_1234                     | TxBD base address of ring n (eTSEC2_TBASE6)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_123C                     | TxBD base address of ring n (eTSEC2_TBASE7)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_1280                     | Tx time stamp identification tag [set n] * (eTSEC2_TMR_TXTS1_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_1284                     | Tx time stamp identification tag [set n] * (eTSEC2_TMR_TXTS2_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_12C0                     | Tx time stamp high [set n] * (eTSEC2_TMR_TXTS1_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_12C4                     | Tx time stamp low [set n] * (eTSEC2_TMR_TXTS1_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_12C8                     | Tx time stamp high [set n] * (eTSEC2_TMR_TXTS2_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_12CC                     | Tx time stamp low [set n] * (eTSEC2_TMR_TXTS2_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_1300                     | Receive control register (eTSEC2_RCTRL)                          | 32                 | R/W    | 0000_0000h  | 15.5.26/<br>969  |

| Offset<br>address<br>(hex) | Register name                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_1304                     | Receive status register (eTSEC2_RSTAT0)                       | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972  |
| B_1310                     | Receive interrupt coalescing register (eTSEC2_RXIC)           | 32                 | R/W    | 0000_0000h  | 15.5.28/<br>975  |
| B_1314                     | Receive queue control register * (eTSEC2_RQUEUE)              | 32                 | R/W    | 0080_0080h  | 15.5.29/<br>976  |
| B_1318                     | Ring mapping register n * (eTSEC2_RIR0)                       | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_131C                     | Ring mapping register n * (eTSEC2_RIR1)                       | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_1320                     | Ring mapping register n * (eTSEC2_RIR2)                       | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_1324                     | Ring mapping register n * (eTSEC2_RIR3)                       | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_1330                     | Receive bit field extract control register * (eTSEC2_RBIFX)   | 32                 | R/W    | 0000_0000h  | 15.5.31/<br>979  |
| B_1334                     | Receive queue filing table address register * (eTSEC2_RQFAR)  | 32                 | R/W    | 0000_0000h  | 15.5.32/<br>981  |
| B_1338                     | Receive queue filer table control register * (eTSEC2_RQFCR)   | 32                 | R/W    | 0000_0000h  | 15.5.33/<br>982  |
| B_133C                     | Receive queue filing table property register * (eTSEC2_RQFPR) | 32                 | R/W    | 0000_0000h  | 15.5.34/<br>984  |
| B_1340                     | Maximum receive buffer length register (eTSEC2_MRBLR)         | 32                 | R/W    | 0000_0000h  | 15.5.35/<br>988  |
| B_1350                     | Receive packet wakeup timer register (eTSEC2_RPWT)            | 32                 | R/W    | 0000_0000h  | 15.5.36/<br>989  |
| B_1380                     | Rx data buffer pointer high bits * (eTSEC2_RBDBPH)            | 32                 | R/W    | 0000_0000h  | 15.5.37/<br>990  |
| B_1384                     | RxBD pointer for ring n (eTSEC2_RBPTR0)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_138C                     | RxBD pointer for ring n (eTSEC2_RBPTR1)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_1394                     | RxBD pointer for ring n (eTSEC2_RBPTR2)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_139C                     | RxBD pointer for ring n (eTSEC2_RBPTR3)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_13A4                     | RxBD pointer for ring n (eTSEC2_RBPTR4)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_13AC                     | RxBD pointer for ring n (eTSEC2_RBPTR5)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_13B4                     | RxBD pointer for ring n (eTSEC2_RBPTR6)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_13BC                     | RxBD pointer for ring n (eTSEC2_RBPTR7)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |

| Offset address (hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_1400               | RxBD base address high bits * (eTSEC2_RBASEH)           | 32                 | R/W    | 0000_0000h  | 15.5.39/<br>991  |
| B_1404               | RxBD base address of ring n (eTSEC2_RBASE0)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_140C               | RxBD base address of ring n (eTSEC2_RBASE1)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_1414               | RxBD base address of ring n (eTSEC2_RBASE2)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_141C               | RxBD base address of ring n (eTSEC2_RBASE3)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_1424               | RxBD base address of ring n (eTSEC2_RBASE4)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_142C               | RxBD base address of ring n (eTSEC2_RBASE5)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_1434               | RxBD base address of ring n (eTSEC2_RBASE6)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_143C               | RxBD base address of ring n (eTSEC2_RBASE7)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_14C0               | Rx timer time stamp register high * (eTSEC2_TMR_RXTS_H) | 32                 | R      | 0000_0000h  | 15.5.41/<br>992  |
| B_14C4               | Rx timer time stamp register low * (eTSEC2_TMR_RXTS_L)  | 32                 | R      | 0000_0000h  | 15.5.42/<br>993  |
| B_1500               | MAC configuration register 1 (eTSEC2_MACCFG1)           | 32                 | R/W    | 0000_0000h  | 15.5.43/<br>994  |
| B_1504               | MAC configuration register 2 (eTSEC2_MACCFG2)           | 32                 | R/W    | 0000_7000h  | 15.5.44/<br>996  |
| B_1508               | Interpacket/interframe gap register (eTSEC2_IPGIFG)     | 32                 | R/W    | 4060_5060h  | 15.5.45/<br>998  |
| B_150C               | Half-duplex control (eTSEC2_HAFDUP)                     | 32                 | R/W    | 00A1_F037h  | 15.5.46/<br>1000 |
| B_1510               | Maximum frame length (eTSEC2_MAXFRM)                    | 32                 | R/W    | 0000_0600h  | 15.5.47/<br>1001 |
| B_153C               | Interface status (eTSEC2_IFSTAT)                        | 32                 | R      | 0000_0000h  | 15.5.48/<br>1001 |
| B_1540               | MAC station address register 1 (eTSEC2_MACSTNADDR1)     | 32                 | R/W    | 0000_0000h  | 15.5.49/<br>1003 |
| B_1544               | MAC station address register 2 (eTSEC2_MACSTNADDR2)     | 32                 | R/W    | 0000_0000h  | 15.5.50/<br>1003 |
| B_1548               | MAC exact match address n, part 1 * (eTSEC2_MAC01ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_154C               | MAC exact match address n, part 2 * (eTSEC2_MAC01ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1550               | MAC exact match address n, part 1 * (eTSEC2_MAC02ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |

| Offset<br>address<br>(hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_1554                     | MAC exact match address n, part 2 * (eTSEC2_MAC02ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1558                     | MAC exact match address n, part 1 * (eTSEC2_MAC03ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_155C                     | MAC exact match address n, part 2 * (eTSEC2_MAC03ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1560                     | MAC exact match address n, part 1 * (eTSEC2_MAC04ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_1564                     | MAC exact match address n, part 2 * (eTSEC2_MAC04ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1568                     | MAC exact match address n, part 1 * (eTSEC2_MAC05ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_156C                     | MAC exact match address n, part 2 * (eTSEC2_MAC05ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1570                     | MAC exact match address n, part 1 * (eTSEC2_MAC06ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_1574                     | MAC exact match address n, part 2 * (eTSEC2_MAC06ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1578                     | MAC exact match address n, part 1 * (eTSEC2_MAC07ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_157C                     | MAC exact match address n, part 2 * (eTSEC2_MAC07ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1580                     | MAC exact match address n, part 1 * (eTSEC2_MAC08ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_1584                     | MAC exact match address n, part 2 * (eTSEC2_MAC08ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1588                     | MAC exact match address n, part 1 * (eTSEC2_MAC09ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_158C                     | MAC exact match address n, part 2 * (eTSEC2_MAC09ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1590                     | MAC exact match address n, part 1 * (eTSEC2_MAC10ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_1594                     | MAC exact match address n, part 2 * (eTSEC2_MAC10ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1598                     | MAC exact match address n, part 1 * (eTSEC2_MAC11ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_159C                     | MAC exact match address n, part 2 * (eTSEC2_MAC11ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_15A0                     | MAC exact match address n, part 1 * (eTSEC2_MAC12ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_15A4                     | MAC exact match address n, part 2 * (eTSEC2_MAC12ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_15A8                     | MAC exact match address n, part 1 * (eTSEC2_MAC13ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |

| Offset<br>address<br>(hex) | Register name                                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_15AC                     | MAC exact match address n, part 2 * (eTSEC2_MAC13ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_15B0                     | MAC exact match address n, part 1 * (eTSEC2_MAC14ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_15B4                     | MAC exact match address n, part 2 * (eTSEC2_MAC14ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_15B8                     | MAC exact match address n, part 1 * (eTSEC2_MAC15ADDR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_15BC                     | MAC exact match address n, part 2 * (eTSEC2_MAC15ADDR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_1680                     | Transmit and receive 64-byte frame counter (eTSEC2_TR64)                     | 32                 | R/W    | 0000_0000h  | 15.5.53/<br>1006 |
| B_1684                     | Transmit and receive 65- to 127-byte frame counter (eTSEC2_TR127)            | 32                 | R/W    | 0000_0000h  | 15.5.54/<br>1006 |
| B_1688                     | Transmit and receive 128- to 255-byte frame counter (eTSEC2_TR255)           | 32                 | R/W    | 0000_0000h  | 15.5.55/<br>1007 |
| B_168C                     | Transmit and receive 256- to 511-byte frame counter (eTSEC2_TR511)           | 32                 | R/W    | 0000_0000h  | 15.5.56/<br>1007 |
| B_1690                     | Transmit and receive 512- to 1023-byte frame counter (eTSEC2_TR1K)           | 32                 | R/W    | 0000_0000h  | 15.5.57/<br>1008 |
| B_1694                     | Transmit and receive 1024- to 1518-byte frame counter (eTSEC2_TRMAX)         | 32                 | R/W    | 0000_0000h  | 15.5.58/<br>1008 |
| B_1698                     | Transmit and receive 1519- to 1522-byte good VLAN frame count (eTSEC2_TRMGV) | 32                 | R/W    | 0000_0000h  | 15.5.59/<br>1009 |
| B_169C                     | Receive byte counter (eTSEC2_RBYT)                                           | 32                 | R/W    | 0000_0000h  | 15.5.60/<br>1009 |
| B_16A0                     | Receive packet counter (eTSEC2_RPKT)                                         | 32                 | R/W    | 0000_0000h  | 15.5.61/<br>1010 |
| B_16A4                     | Receive FCS error counter (eTSEC2_RFCS)                                      | 32                 | R/W    | 0000_0000h  | 15.5.62/<br>1010 |
| B_16A8                     | Receive multicast packet counter (eTSEC2_RMCA)                               | 32                 | R/W    | 0000_0000h  | 15.5.63/<br>1011 |
| B_16AC                     | Receive broadcast packet counter (eTSEC2_RBCA)                               | 32                 | R/W    | 0000_0000h  | 15.5.64/<br>1011 |
| B_16B0                     | Receive control frame packet counter (eTSEC2_RXCF)                           | 32                 | R/W    | 0000_0000h  | 15.5.65/<br>1012 |
| B_16B4                     | Receive PAUSE frame packet counter (eTSEC2_RXPF)                             | 32                 | R/W    | 0000_0000h  | 15.5.66/<br>1012 |
| B_16B8                     | Receive unknown OP code counter (eTSEC2_RXUO)                                | 32                 | R/W    | 0000_0000h  | 15.5.67/<br>1013 |
| B_16BC                     | Receive alignment error counter (eTSEC2_RALN)                                | 32                 | R/W    | 0000_0000h  | 15.5.68/<br>1013 |
| B_16C0                     | Receive frame length error counter (eTSEC2_RFLR)                             | 32                 | R/W    | 0000_0000h  | 15.5.69/<br>1014 |

| Offset address (hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-----------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_16C4               | Receive code error counter (eTSEC2_RCDE)                  | 32                 | R/W    | 0000_0000h  | 15.5.70/<br>1014 |
| B_16C8               | Receive carrier sense error counter (eTSEC2_RCSE)         | 32                 | R/W    | 0000_0000h  | 15.5.71/<br>1015 |
| B_16CC               | Receive undersize packet counter (eTSEC2_RUND)            | 32                 | R/W    | 0000_0000h  | 15.5.72/<br>1015 |
| B_16D0               | Receive oversize packet counter (eTSEC2_ROVR)             | 32                 | R/W    | 0000_0000h  | 15.5.73/<br>1016 |
| B_16D4               | Receive fragments counter (eTSEC2_RFRG)                   | 32                 | R/W    | 0000_0000h  | 15.5.74/<br>1016 |
| B_16D8               | Receive jabber counter (eTSEC2_RJBR)                      | 32                 | R/W    | 0000_0000h  | 15.5.75/<br>1017 |
| B_16DC               | Receive drop counter (eTSEC2_RDRP)                        | 32                 | R/W    | 0000_0000h  | 15.5.76/<br>1017 |
| B_16E0               | Transmit byte counter (eTSEC2_TBYT)                       | 32                 | R/W    | 0000_0000h  | 15.5.77/<br>1018 |
| B_16E4               | Transmit packet counter (eTSEC2_TPKT)                     | 32                 | R/W    | 0000_0000h  | 15.5.78/<br>1018 |
| B_16E8               | Transmit multicast packet counter (eTSEC2_TMCA)           | 32                 | R/W    | 0000_0000h  | 15.5.79/<br>1019 |
| B_16EC               | Transmit broadcast packet counter (eTSEC2_TBCA)           | 32                 | R/W    | 0000_0000h  | 15.5.80/<br>1019 |
| B_16F0               | Transmit PAUSE control frame counter (eTSEC2_TXPF)        | 32                 | R/W    | 0000_0000h  | 15.5.81/<br>1020 |
| B_16F4               | Transmit deferral packet counter (eTSEC2_TDFR)            | 32                 | R/W    | 0000_0000h  | 15.5.82/<br>1020 |
| B_16F8               | Transmit excessive deferral packet counter (eTSEC2_TEDF)  | 32                 | R/W    | 0000_0000h  | 15.5.83/<br>1021 |
| B_16FC               | Transmit single collision packet counter (eTSEC2_TSCL)    | 32                 | R/W    | 0000_0000h  | 15.5.84/<br>1021 |
| B_1700               | Transmit multiple collision packet counter (eTSEC2_TMCL)  | 32                 | R/W    | 0000_0000h  | 15.5.85/<br>1022 |
| B_1704               | Transmit late collision packet counter (eTSEC2_TLCL)      | 32                 | R/W    | 0000_0000h  | 15.5.86/<br>1022 |
| B_1708               | Transmit excessive collision packet counter (eTSEC2_TXCL) | 32                 | R/W    | 0000_0000h  | 15.5.87/<br>1023 |
| B_170C               | Transmit total collision counter (eTSEC2_TNCL)            | 32                 | R/W    | 0000_0000h  | 15.5.88/<br>1023 |
| B_1714               | Transmit drop frame counter (eTSEC2_TDRP)                 | 32                 | R/W    | 0000_0000h  | 15.5.89/<br>1024 |
| B_1718               | Transmit jabber frame counter (eTSEC2_TJBR)               | 32                 | R/W    | 0000_0000h  | 15.5.90/<br>1024 |
| B_171C               | Transmit FCS error counter (eTSEC2_TFCS)                  | 32                 | R/W    | 0000_0000h  | 15.5.91/<br>1025 |

| Offset<br>address<br>(hex) | Register name                                         | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|-------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_1720                     | Transmit control frame counter (eTSEC2_TXCF)          | 32                 | R/W    | 0000_0000h  | 15.5.92/<br>1025  |
| B_1724                     | Transmit oversize frame counter (eTSEC2_TOVR)         | 32                 | R/W    | 0000_0000h  | 15.5.93/<br>1026  |
| B_1728                     | Transmit undersize frame counter (eTSEC2_TUND)        | 32                 | R/W    | 0000_0000h  | 15.5.94/<br>1026  |
| B_172C                     | Transmit fragments frame counter (eTSEC2_TFRG)        | 32                 | R/W    | 0000_0000h  | 15.5.95/<br>1027  |
| B_1730                     | Carry register one (eTSEC2_CAR1)                      | 32                 | R/W    | 0000_0000h  | 15.5.96/<br>1028  |
| B_1734                     | Carry register two (eTSEC2_CAR2)                      | 32                 | R/W    | 0000_0000h  | 15.5.97/<br>1030  |
| B_1738                     | Carry register one mask register (eTSEC2_CAM1)        | 32                 | R/W    | FE03_FFFFh  | 15.5.98/<br>1032  |
| B_173C                     | Carry register two mask register (eTSEC2_CAM2)        | 32                 | R/W    | 000F_FFFDh  | 15.5.99/<br>1034  |
| B_1740                     | Receive filer rejected packet counter * (eTSEC2_RREJ) | 32                 | R/W    | 0000_0000h  | 15.5.100/<br>1035 |
| B_1800                     | Individual/group address register n (eTSEC2_IGADDR0)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1804                     | Individual/group address register n (eTSEC2_IGADDR1)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1808                     | Individual/group address register n (eTSEC2_IGADDR2)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_180C                     | Individual/group address register n (eTSEC2_IGADDR3)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1810                     | Individual/group address register n (eTSEC2_IGADDR4)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1814                     | Individual/group address register n (eTSEC2_IGADDR5)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1818                     | Individual/group address register n (eTSEC2_IGADDR6)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_181C                     | Individual/group address register n (eTSEC2_IGADDR7)  | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_1880                     | Group address register n (eTSEC2_GADDR0)              | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_1884                     | Group address register n (eTSEC2_GADDR1)              | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_1888                     | Group address register n (eTSEC2_GADDR2)              | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_188C                     | Group address register n (eTSEC2_GADDR3)              | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_1890                     | Group address register n (eTSEC2_GADDR4)              | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |

| Offset<br>address<br>(hex) | Register name                                                          | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|------------------------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_1894                     | Group address register n (eTSEC2_GADDR5)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_1898                     | Group address register n (eTSEC2_GADDR6)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_189C                     | Group address register n (eTSEC2_GADDR7)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_1BF8                     | Attribute register (eTSEC2_ATTR)                                       | 32                 | R/W    | 0000_0000h  | 15.5.103/<br>1037 |
| B_1BFC                     | Attribute extract length and extract index register * (eTSEC2_ATTRELI) | 32                 | R/W    | 0000_0000h  | 15.5.104/<br>1039 |
| B_1C00                     | Receive Queue Parameters register n * (eTSEC2_RQPRM0)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C04                     | Receive Queue Parameters register n * (eTSEC2_RQPRM1)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C08                     | Receive Queue Parameters register n * (eTSEC2_RQPRM2)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C0C                     | Receive Queue Parameters register n * (eTSEC2_RQPRM3)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C10                     | Receive Queue Parameters register n * (eTSEC2_RQPRM4)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C14                     | Receive Queue Parameters register n * (eTSEC2_RQPRM5)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C18                     | Receive Queue Parameters register n * (eTSEC2_RQPRM6)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C1C                     | Receive Queue Parameters register n * (eTSEC2_RQPRM7)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_1C44                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR0)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C4C                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR1)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C54                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR2)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C5C                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR3)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C64                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR4)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C6C                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR5)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C74                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR6)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1C7C                     | Last Free RxBD pointer for ring n * (eTSEC2_RFBPTR7)                   | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_1EB0                     | Interrupt steering register group n (eTSEC2_ISRG0)                     | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |

| Offset<br>address<br>(hex) | Register name                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|----------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_1EB4                     | Interrupt steering register group n (eTSEC2_ISRG1) | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |
| B_1ED0                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC0)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1ED4                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC1)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1ED8                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC2)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1EDC                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC3)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1EE0                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC4)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1EE4                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC5)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1EE8                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC6)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1EEC                     | Ring n Rx interrupt coalescing (eTSEC2_RXIC7)      | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_1F10                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC0)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F14                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC1)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F18                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC2)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F1C                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC3)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F20                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC4)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F24                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC5)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F28                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC6)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_1F2C                     | Ring n Tx interrupt coalescing (eTSEC2_TXIC7)      | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_5010                     | Group Interrupt event register (eTSEC2_IEVENTG1)   | 32                 | w1c    | 0000_0000h  | 15.5.4/933        |
| B_5014                     | Group Interrupt mask register (eTSEC2_IMASKG1)     | 32                 | R/W    | 0000_0000h  | 15.5.5/939        |
| B_5104                     | Transmit status register (eTSEC2_TSTAT1)           | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956   |
| B_5304                     | Receive status register (eTSEC2_RSTAT1)            | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972   |
| B_2000                     | Controller ID register * (eTSEC3_TSEC_ID)          | 32                 | R      | 0124_0200h  | 15.5.2/931        |
| B_2004                     | Controller ID register * (eTSEC3_TSEC_ID2)         | 32                 | R      | See section | 15.5.3/932        |
| B_2010                     | Group Interrupt event register (eTSEC3_IEVENTG0)   | 32                 | w1c    | 0000_0000h  | 15.5.4/933        |

| Offset<br>address<br>(hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_2014                     | Group Interrupt mask register (eTSEC3_IMASKG0)          | 32                 | R/W    | 0000_0000h  | 15.5.5/939       |
| B_2018                     | Error disabled register (eTSEC3_EDIS)                   | 32                 | R/W    | 0000_0000h  | 15.5.6/941       |
| B_201C                     | Group Error mapping register (eTSEC3_EMAPG)             | 32                 | R/W    | 0000_0000h  | 15.5.7/943       |
| B_2020                     | Ethernet control register (eTSEC3_ECNTRL)               | 32                 | R/W    | 0000_0000h  | 15.5.8/945       |
| B_2028                     | Pause time value register (eTSEC3_PTV)                  | 32                 | R/W    | 0000_0000h  | 15.5.9/949       |
| B_202C                     | DMA control register (eTSEC3_DMACTRL)                   | 32                 | R/W    | 0000_0000h  | 15.5.10/<br>950  |
| B_2030                     | TBI PHY address register (eTSEC3_TBIPA)                 | 32                 | R/W    | 0000_0000h  | 15.5.11/<br>952  |
| B_2100                     | Transmit control register (eTSEC3_TCTRL)                | 32                 | R/W    | 0000_0000h  | 15.5.12/<br>952  |
| B_2104                     | Transmit status register (eTSEC3_TSTAT0)                | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956  |
| B_2108                     | Default VLAN control word * (eTSEC3_DFVLAN)             | 32                 | R/W    | 8100_0000h  | 15.5.14/<br>960  |
| B_2110                     | Transmit interrupt coalescing register (eTSEC3_TXIC)    | 32                 | R/W    | 0000_0000h  | 15.5.15/<br>961  |
| B_2114                     | Transmit queue control register * (eTSEC3_TQUEUE)       | 32                 | R/W    | 0000_8000h  | 15.5.16/<br>962  |
| B_2140                     | TxBD Rings 0-3 round-robin weightings * (eTSEC3_TR03WT) | 32                 | R/W    | 0000_0000h  | 15.5.17/<br>963  |
| B_2144                     | TxBD Rings 4-7 round-robin weightings * (eTSEC3_TR47WT) | 32                 | R/W    | 0000_0000h  | 15.5.18/<br>964  |
| B_2180                     | Tx data buffer pointer high bits * (eTSEC3_TBDBPH)      | 32                 | R/W    | 0000_0000h  | 15.5.19/<br>965  |
| B_2184                     | TxBD pointer for ring n (eTSEC3_TBPTR0)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_218C                     | TxBD pointer for ring n (eTSEC3_TBPTR1)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_2194                     | TxBD pointer for ring n (eTSEC3_TBPTR2)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_219C                     | TxBD pointer for ring n (eTSEC3_TBPTR3)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_21A4                     | TxBD pointer for ring n (eTSEC3_TBPTR4)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_21AC                     | TxBD pointer for ring n (eTSEC3_TBPTR5)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_21B4                     | TxBD pointer for ring n (eTSEC3_TBPTR6)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_21BC                     | TxBD pointer for ring n (eTSEC3_TBPTR7)                 | 32                 | R/W    | 0000_0000h  | 15.5.20/<br>966  |
| B_2200                     | TxBD base address high bits * (eTSEC3_TBASEH)           | 32                 | R/W    | 0000_0000h  | 15.5.21/<br>966  |

| Offset<br>address<br>(hex) | Register name                                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_2204                     | TxBD base address of ring n (eTSEC3_TBASE0)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_220C                     | TxBD base address of ring n (eTSEC3_TBASE1)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_2214                     | TxBD base address of ring n (eTSEC3_TBASE2)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_221C                     | TxBD base address of ring n (eTSEC3_TBASE3)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_2224                     | TxBD base address of ring n (eTSEC3_TBASE4)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_222C                     | TxBD base address of ring n (eTSEC3_TBASE5)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_2234                     | TxBD base address of ring n (eTSEC3_TBASE6)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_223C                     | TxBD base address of ring n (eTSEC3_TBASE7)                      | 32                 | R/W    | 0000_0000h  | 15.5.22/<br>967  |
| B_2280                     | Tx time stamp identification tag [set n] * (eTSEC3_TMR_TXTS1_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_2284                     | Tx time stamp identification tag [set n] * (eTSEC3_TMR_TXTS2_ID) | 32                 | R      | 0000_0000h  | 15.5.23/<br>967  |
| B_22C0                     | Tx time stamp high [set n] * (eTSEC3_TMR_TXTS1_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_22C4                     | Tx time stamp low [set n] * (eTSEC3_TMR_TXTS1_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_22C8                     | Tx time stamp high [set n] * (eTSEC3_TMR_TXTS2_H)                | 32                 | R      | 0000_0000h  | 15.5.24/<br>968  |
| B_22CC                     | Tx time stamp low [set n] * (eTSEC3_TMR_TXTS2_L)                 | 32                 | R      | 0000_0000h  | 15.5.25/<br>968  |
| B_2300                     | Receive control register (eTSEC3_RCTRL)                          | 32                 | R/W    | 0000_0000h  | 15.5.26/<br>969  |
| B_2304                     | Receive status register (eTSEC3_RSTAT0)                          | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972  |
| B_2310                     | Receive interrupt coalescing register (eTSEC3_RXIC)              | 32                 | R/W    | 0000_0000h  | 15.5.28/<br>975  |
| B_2314                     | Receive queue control register * (eTSEC3_RQUEUE)                 | 32                 | R/W    | 0080_0080h  | 15.5.29/<br>976  |
| B_2318                     | Ring mapping register n * (eTSEC3_RIR0)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_231C                     | Ring mapping register n * (eTSEC3_RIR1)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_2320                     | Ring mapping register n * (eTSEC3_RIR2)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |
| B_2324                     | Ring mapping register n * (eTSEC3_RIR3)                          | 32                 | R/W    | 0000_0000h  | 15.5.30/<br>978  |

| Offset<br>address<br>(hex) | Register name                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_2330                     | Receive bit field extract control register * (eTSEC3_RBIFX)   | 32                 | R/W    | 0000_0000h  | 15.5.31/<br>979  |
| B_2334                     | Receive queue filing table address register * (eTSEC3_RQFAR)  | 32                 | R/W    | 0000_0000h  | 15.5.32/<br>981  |
| B_2338                     | Receive queue filer table control register * (eTSEC3_RQFCR)   | 32                 | R/W    | 0000_0000h  | 15.5.33/<br>982  |
| B_233C                     | Receive queue filing table property register * (eTSEC3_RQFPR) | 32                 | R/W    | 0000_0000h  | 15.5.34/<br>984  |
| B_2340                     | Maximum receive buffer length register (eTSEC3_MRBLR)         | 32                 | R/W    | 0000_0000h  | 15.5.35/<br>988  |
| B_2350                     | Receive packet wakeup timer register (eTSEC3_RPWT)            | 32                 | R/W    | 0000_0000h  | 15.5.36/<br>989  |
| B_2380                     | Rx data buffer pointer high bits * (eTSEC3_RBDBPH)            | 32                 | R/W    | 0000_0000h  | 15.5.37/<br>990  |
| B_2384                     | RxBD pointer for ring n (eTSEC3_RBPTR0)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_238C                     | RxBD pointer for ring n (eTSEC3_RBPTR1)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_2394                     | RxBD pointer for ring n (eTSEC3_RBPTR2)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_239C                     | RxBD pointer for ring n (eTSEC3_RBPTR3)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_23A4                     | RxBD pointer for ring n (eTSEC3_RBPTR4)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_23AC                     | RxBD pointer for ring n (eTSEC3_RBPTR5)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_23B4                     | RxBD pointer for ring n (eTSEC3_RBPTR6)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_23BC                     | RxBD pointer for ring n (eTSEC3_RBPTR7)                       | 32                 | R/W    | 0000_0000h  | 15.5.38/<br>990  |
| B_2400                     | RxBD base address high bits * (eTSEC3_RBASEH)                 | 32                 | R/W    | 0000_0000h  | 15.5.39/<br>991  |
| B_2404                     | RxBD base address of ring n (eTSEC3_RBASE0)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_240C                     | RxBD base address of ring n (eTSEC3_RBASE1)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_2414                     | RxBD base address of ring n (eTSEC3_RBASE2)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_241C                     | RxBD base address of ring n (eTSEC3_RBASE3)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_2424                     | RxBD base address of ring n (eTSEC3_RBASE4)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_242C                     | RxBD base address of ring n (eTSEC3_RBASE5)                   | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |

| Offset<br>address<br>(hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_2434                     | RxBD base address of ring n (eTSEC3_RBASE6)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_243C                     | RxBD base address of ring n (eTSEC3_RBASE7)             | 32                 | R/W    | 0000_0000h  | 15.5.40/<br>992  |
| B_24C0                     | Rx timer time stamp register high * (eTSEC3_TMR_RXTS_H) | 32                 | R      | 0000_0000h  | 15.5.41/<br>992  |
| B_24C4                     | Rx timer time stamp register low * (eTSEC3_TMR_RXTS_L)  | 32                 | R      | 0000_0000h  | 15.5.42/<br>993  |
| B_2500                     | MAC configuration register 1 (eTSEC3_MACCFG1)           | 32                 | R/W    | 0000_0000h  | 15.5.43/<br>994  |
| B_2504                     | MAC configuration register 2 (eTSEC3_MACCFG2)           | 32                 | R/W    | 0000_7000h  | 15.5.44/<br>996  |
| B_2508                     | Interpacket/interframe gap register (eTSEC3_IPGIFG)     | 32                 | R/W    | 4060_5060h  | 15.5.45/<br>998  |
| B_250C                     | Half-duplex control (eTSEC3_HAFDUP)                     | 32                 | R/W    | 00A1_F037h  | 15.5.46/<br>1000 |
| B_2510                     | Maximum frame length (eTSEC3_MAXFRM)                    | 32                 | R/W    | 0000_0600h  | 15.5.47/<br>1001 |
| B_253C                     | Interface status (eTSEC3_IFSTAT)                        | 32                 | R      | 0000_0000h  | 15.5.48/<br>1001 |
| B_2540                     | MAC station address register 1 (eTSEC3_MACSTNADDR1)     | 32                 | R/W    | 0000_0000h  | 15.5.49/<br>1003 |
| B_2544                     | MAC station address register 2 (eTSEC3_MACSTNADDR2)     | 32                 | R/W    | 0000_0000h  | 15.5.50/<br>1003 |
| B_2548                     | MAC exact match address n, part 1 * (eTSEC3_MAC01ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_254C                     | MAC exact match address n, part 2 * (eTSEC3_MAC01ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2550                     | MAC exact match address n, part 1 * (eTSEC3_MAC02ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_2554                     | MAC exact match address n, part 2 * (eTSEC3_MAC02ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2558                     | MAC exact match address n, part 1 * (eTSEC3_MAC03ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_255C                     | MAC exact match address n, part 2 * (eTSEC3_MAC03ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2560                     | MAC exact match address n, part 1 * (eTSEC3_MAC04ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_2564                     | MAC exact match address n, part 2 * (eTSEC3_MAC04ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2568                     | MAC exact match address n, part 1 * (eTSEC3_MAC05ADDR1) | 32                 | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_256C                     | MAC exact match address n, part 2 * (eTSEC3_MAC05ADDR2) | 32                 | R/W    | 0000_0000h  | 15.5.52/<br>1005 |

| Offset<br>address<br>(hex) | Register name                                                     | Width (in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------------|-----------------|--------|-------------|------------------|
| B_2570                     | MAC exact match address n, part 1 * (eTSEC3_MAC06ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_2574                     | MAC exact match address n, part 2 * (eTSEC3_MAC06ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2578                     | MAC exact match address n, part 1 * (eTSEC3_MAC07ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_257C                     | MAC exact match address n, part 2 * (eTSEC3_MAC07ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2580                     | MAC exact match address n, part 1 * (eTSEC3_MAC08ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_2584                     | MAC exact match address n, part 2 * (eTSEC3_MAC08ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2588                     | MAC exact match address n, part 1 * (eTSEC3_MAC09ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_258C                     | MAC exact match address n, part 2 * (eTSEC3_MAC09ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2590                     | MAC exact match address n, part 1 * (eTSEC3_MAC10ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_2594                     | MAC exact match address n, part 2 * (eTSEC3_MAC10ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2598                     | MAC exact match address n, part 1 * (eTSEC3_MAC11ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_259C                     | MAC exact match address n, part 2 * (eTSEC3_MAC11ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_25A0                     | MAC exact match address n, part 1 * (eTSEC3_MAC12ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_25A4                     | MAC exact match address n, part 2 * (eTSEC3_MAC12ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_25A8                     | MAC exact match address n, part 1 * (eTSEC3_MAC13ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_25AC                     | MAC exact match address n, part 2 * (eTSEC3_MAC13ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_25B0                     | MAC exact match address n, part 1 * (eTSEC3_MAC14ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_25B4                     | MAC exact match address n, part 2 * (eTSEC3_MAC14ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_25B8                     | MAC exact match address n, part 1 * (eTSEC3_MAC15ADDR1)           | 32              | R/W    | 0000_0000h  | 15.5.51/<br>1004 |
| B_25BC                     | MAC exact match address n, part 2 * (eTSEC3_MAC15ADDR2)           | 32              | R/W    | 0000_0000h  | 15.5.52/<br>1005 |
| B_2680                     | Transmit and receive 64-byte frame counter (eTSEC3_TR64)          | 32              | R/W    | 0000_0000h  | 15.5.53/<br>1006 |
| B_2684                     | Transmit and receive 65- to 127-byte frame counter (eTSEC3_TR127) | 32              | R/W    | 0000_0000h  | 15.5.54/<br>1006 |

| Offset<br>address<br>(hex) | Register name                                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_2688                     | Transmit and receive 128- to 255-byte frame counter (eTSEC3_TR255)           | 32                 | R/W    | 0000_0000h  | 15.5.55/<br>1007 |
| B_268C                     | Transmit and receive 256- to 511-byte frame counter (eTSEC3_TR511)           | 32                 | R/W    | 0000_0000h  | 15.5.56/<br>1007 |
| B_2690                     | Transmit and receive 512- to 1023-byte frame counter (eTSEC3_TR1K)           | 32                 | R/W    | 0000_0000h  | 15.5.57/<br>1008 |
| B_2694                     | Transmit and receive 1024- to 1518-byte frame counter (eTSEC3_TRMAX)         | 32                 | R/W    | 0000_0000h  | 15.5.58/<br>1008 |
| B_2698                     | Transmit and receive 1519- to 1522-byte good VLAN frame count (eTSEC3_TRMGV) | 32                 | R/W    | 0000_0000h  | 15.5.59/<br>1009 |
| B_269C                     | Receive byte counter (eTSEC3_RBYT)                                           | 32                 | R/W    | 0000_0000h  | 15.5.60/<br>1009 |
| B_26A0                     | Receive packet counter (eTSEC3_RPKT)                                         | 32                 | R/W    | 0000_0000h  | 15.5.61/<br>1010 |
| B_26A4                     | Receive FCS error counter (eTSEC3_RFCS)                                      | 32                 | R/W    | 0000_0000h  | 15.5.62/<br>1010 |
| B_26A8                     | Receive multicast packet counter (eTSEC3_RMCA)                               | 32                 | R/W    | 0000_0000h  | 15.5.63/<br>1011 |
| B_26AC                     | Receive broadcast packet counter (eTSEC3_RBCA)                               | 32                 | R/W    | 0000_0000h  | 15.5.64/<br>1011 |
| B_26B0                     | Receive control frame packet counter (eTSEC3_RXCF)                           | 32                 | R/W    | 0000_0000h  | 15.5.65/<br>1012 |
| B_26B4                     | Receive PAUSE frame packet counter (eTSEC3_RXPF)                             | 32                 | R/W    | 0000_0000h  | 15.5.66/<br>1012 |
| B_26B8                     | Receive unknown OP code counter (eTSEC3_RXUO)                                | 32                 | R/W    | 0000_0000h  | 15.5.67/<br>1013 |
| B_26BC                     | Receive alignment error counter (eTSEC3_RALN)                                | 32                 | R/W    | 0000_0000h  | 15.5.68/<br>1013 |
| B_26C0                     | Receive frame length error counter (eTSEC3_RFLR)                             | 32                 | R/W    | 0000_0000h  | 15.5.69/<br>1014 |
| B_26C4                     | Receive code error counter (eTSEC3_RCDE)                                     | 32                 | R/W    | 0000_0000h  | 15.5.70/<br>1014 |
| B_26C8                     | Receive carrier sense error counter (eTSEC3_RCSE)                            | 32                 | R/W    | 0000_0000h  | 15.5.71/<br>1015 |
| B_26CC                     | Receive undersize packet counter (eTSEC3_RUND)                               | 32                 | R/W    | 0000_0000h  | 15.5.72/<br>1015 |
| B_26D0                     | Receive oversize packet counter (eTSEC3_ROVR)                                | 32                 | R/W    | 0000_0000h  | 15.5.73/<br>1016 |
| B_26D4                     | Receive fragments counter (eTSEC3_RFRG)                                      | 32                 | R/W    | 0000_0000h  | 15.5.74/<br>1016 |
| B_26D8                     | Receive jabber counter (eTSEC3_RJBR)                                         | 32                 | R/W    | 0000_0000h  | 15.5.75/<br>1017 |
| B_26DC                     | Receive drop counter (eTSEC3_RDRP)                                           | 32                 | R/W    | 0000_0000h  | 15.5.76/<br>1017 |

| Offset address (hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-----------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_26E0               | Transmit byte counter (eTSEC3_TBYT)                       | 32                 | R/W    | 0000_0000h  | 15.5.77/<br>1018 |
| B_26E4               | Transmit packet counter (eTSEC3_TPKT)                     | 32                 | R/W    | 0000_0000h  | 15.5.78/<br>1018 |
| B_26E8               | Transmit multicast packet counter (eTSEC3_TMCA)           | 32                 | R/W    | 0000_0000h  | 15.5.79/<br>1019 |
| B_26EC               | Transmit broadcast packet counter (eTSEC3_TBCA)           | 32                 | R/W    | 0000_0000h  | 15.5.80/<br>1019 |
| B_26F0               | Transmit PAUSE control frame counter (eTSEC3_TXPF)        | 32                 | R/W    | 0000_0000h  | 15.5.81/<br>1020 |
| B_26F4               | Transmit deferral packet counter (eTSEC3_TDFR)            | 32                 | R/W    | 0000_0000h  | 15.5.82/<br>1020 |
| B_26F8               | Transmit excessive deferral packet counter (eTSEC3_TEDF)  | 32                 | R/W    | 0000_0000h  | 15.5.83/<br>1021 |
| B_26FC               | Transmit single collision packet counter (eTSEC3_TSCL)    | 32                 | R/W    | 0000_0000h  | 15.5.84/<br>1021 |
| B_2700               | Transmit multiple collision packet counter (eTSEC3_TMCL)  | 32                 | R/W    | 0000_0000h  | 15.5.85/<br>1022 |
| B_2704               | Transmit late collision packet counter (eTSEC3_TLCL)      | 32                 | R/W    | 0000_0000h  | 15.5.86/<br>1022 |
| B_2708               | Transmit excessive collision packet counter (eTSEC3_TXCL) | 32                 | R/W    | 0000_0000h  | 15.5.87/<br>1023 |
| B_270C               | Transmit total collision counter (eTSEC3_TNCL)            | 32                 | R/W    | 0000_0000h  | 15.5.88/<br>1023 |
| B_2714               | Transmit drop frame counter (eTSEC3_TDRP)                 | 32                 | R/W    | 0000_0000h  | 15.5.89/<br>1024 |
| B_2718               | Transmit jabber frame counter (eTSEC3_TJBR)               | 32                 | R/W    | 0000_0000h  | 15.5.90/<br>1024 |
| B_271C               | Transmit FCS error counter (eTSEC3_TFCS)                  | 32                 | R/W    | 0000_0000h  | 15.5.91/<br>1025 |
| B_2720               | Transmit control frame counter (eTSEC3_TXCF)              | 32                 | R/W    | 0000_0000h  | 15.5.92/<br>1025 |
| B_2724               | Transmit oversize frame counter (eTSEC3_TOVR)             | 32                 | R/W    | 0000_0000h  | 15.5.93/<br>1026 |
| B_2728               | Transmit undersize frame counter (eTSEC3_TUND)            | 32                 | R/W    | 0000_0000h  | 15.5.94/<br>1026 |
| B_272C               | Transmit fragments frame counter (eTSEC3_TFRG)            | 32                 | R/W    | 0000_0000h  | 15.5.95/<br>1027 |
| B_2730               | Carry register one (eTSEC3_CAR1)                          | 32                 | R/W    | 0000_0000h  | 15.5.96/<br>1028 |
| B_2734               | Carry register two (eTSEC3_CAR2)                          | 32                 | R/W    | 0000_0000h  | 15.5.97/<br>1030 |
| B_2738               | Carry register one mask register (eTSEC3_CAM1)            | 32                 | R/W    | FE03_FFFFh  | 15.5.98/<br>1032 |

| Offset<br>address<br>(hex) | Register name                                                          | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|------------------------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_273C                     | Carry register two mask register (eTSEC3_CAM2)                         | 32                 | R/W    | 000F_FFFDh  | 15.5.99/<br>1034  |
| B_2740                     | Receive filer rejected packet counter * (eTSEC3_RREJ)                  | 32                 | R/W    | 0000_0000h  | 15.5.100/<br>1035 |
| B_2800                     | Individual/group address register n (eTSEC3_IGADDR0)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2804                     | Individual/group address register n (eTSEC3_IGADDR1)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2808                     | Individual/group address register n (eTSEC3_IGADDR2)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_280C                     | Individual/group address register n (eTSEC3_IGADDR3)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2810                     | Individual/group address register n (eTSEC3_IGADDR4)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2814                     | Individual/group address register n (eTSEC3_IGADDR5)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2818                     | Individual/group address register n (eTSEC3_IGADDR6)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_281C                     | Individual/group address register n (eTSEC3_IGADDR7)                   | 32                 | R/W    | 0000_0000h  | 15.5.101/<br>1036 |
| B_2880                     | Group address register n (eTSEC3_GADDR0)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2884                     | Group address register n (eTSEC3_GADDR1)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2888                     | Group address register n (eTSEC3_GADDR2)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_288C                     | Group address register n (eTSEC3_GADDR3)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2890                     | Group address register n (eTSEC3_GADDR4)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2894                     | Group address register n (eTSEC3_GADDR5)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2898                     | Group address register n (eTSEC3_GADDR6)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_289C                     | Group address register n (eTSEC3_GADDR7)                               | 32                 | R/W    | 0000_0000h  | 15.5.102/<br>1037 |
| B_2BF8                     | Attribute register (eTSEC3_ATTR)                                       | 32                 | R/W    | 0000_0000h  | 15.5.103/<br>1037 |
| B_2BFC                     | Attribute extract length and extract index register * (eTSEC3_ATTRELI) | 32                 | R/W    | 0000_0000h  | 15.5.104/<br>1039 |
| B_2C00                     | Receive Queue Parameters register n * (eTSEC3_RQPRM0)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C04                     | Receive Queue Parameters register n * (eTSEC3_RQPRM1)                  | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |

| Offset<br>address<br>(hex) | Register name                                         | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|-------------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_2C08                     | Receive Queue Parameters register n * (eTSEC3_RQPRM2) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C0C                     | Receive Queue Parameters register n * (eTSEC3_RQPRM3) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C10                     | Receive Queue Parameters register n * (eTSEC3_RQPRM4) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C14                     | Receive Queue Parameters register n * (eTSEC3_RQPRM5) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C18                     | Receive Queue Parameters register n * (eTSEC3_RQPRM6) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C1C                     | Receive Queue Parameters register n * (eTSEC3_RQPRM7) | 32                 | R/W    | 0000_0000h  | 15.5.105/<br>1040 |
| B_2C44                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR0)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C4C                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR1)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C54                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR2)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C5C                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR3)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C64                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR4)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C6C                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR5)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C74                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR6)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2C7C                     | Last Free RxBD pointer for ring n * (eTSEC3_RFBPTR7)  | 32                 | R/W    | 0000_0000h  | 15.5.106/<br>1041 |
| B_2EB0                     | Interrupt steering register group n (eTSEC3_ISRG0)    | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |
| B_2EB4                     | Interrupt steering register group n (eTSEC3_ISRG1)    | 32                 | R/W    | 0000_0000h  | 15.5.107/<br>1041 |
| B_2ED0                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC0)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2ED4                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC1)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2ED8                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC2)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2EDC                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC3)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2EE0                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC4)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2EE4                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC5)         | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |

| Offset<br>address<br>(hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page  |
|----------------------------|--------------------------------------------------|--------------------|--------|-------------|-------------------|
| B_2EE8                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC6)    | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2EEC                     | Ring n Rx interrupt coalescing (eTSEC3_RXIC7)    | 32                 | R/W    | 0000_0000h  | 15.5.108/<br>1044 |
| B_2F10                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC0)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F14                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC1)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F18                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC2)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F1C                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC3)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F20                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC4)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F24                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC5)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F28                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC6)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_2F2C                     | Ring n Tx interrupt coalescing (eTSEC3_TXIC7)    | 32                 | R/W    | 0000_0000h  | 15.5.109/<br>1046 |
| B_6010                     | Group Interrupt event register (eTSEC3_IEVENTG1) | 32                 | w1c    | 0000_0000h  | 15.5.4/933        |
| B_6014                     | Group Interrupt mask register (eTSEC3_IMASKG1)   | 32                 | R/W    | 0000_0000h  | 15.5.5/939        |
| B_6104                     | Transmit status register (eTSEC3_TSTAT1)         | 32                 | w1c    | 0000_0000h  | 15.5.13/<br>956   |
| B_6304                     | Receive status register (eTSEC3_RSTAT1)          | 32                 | w1c    | 0000_0000h  | 15.5.27/<br>972   |

#### 15.5.2 Controller ID register \* (eTSECx\_TSEC\_ID)

The following sections describe general control and status registers used for both transmitting and receiving Ethernet frames. All of the registers are 32 bits wide.

The controller ID register (TSEC\_ID) is a read-only register. The TSEC\_ID register is used to identify the eTSEC block and revision.

#### Address: Base address + 0h offset



#### eTSEC memory map/register definition

#### eTSECx\_TSEC\_ID field descriptions

| Field                | Description                                                   |
|----------------------|---------------------------------------------------------------|
| 0–15<br>TSEC ID      | Value identifying the eTSEC (10/100/1000 Ethernet MAC).       |
| .0200                | 0124 Unique identifier for eTSEC with 8 Rx and 8 Tx BD rings. |
| 16–23<br>TSEC REV MJ | Value identifies the major revision of the eTSEC.             |
|                      | 02 Initial revision                                           |
| 24–31<br>TSEC REV MN | Value identifies the minor revision of the eTSEC.             |
|                      | 00 Initial revision                                           |

# 15.5.3 Controller ID register \* (eTSECx\_TSEC\_ID2)

The controller ID register (TSEC\_ID2) is a read-only register . The TSEC\_ID2 register is used to identify the eTSEC block configuration.

Table 15-247. TSEC\_ID2[TSEC\_INT] Field Settings

| Bit   | Mode                                                    |
|-------|---------------------------------------------------------|
| 8     | 0 1588 timer not supported                              |
|       | 1 1588 timer supported                                  |
| 9     | 0 SGMII not supported                                   |
|       | 1 SGMII supported                                       |
| 10    | 0 Ethernet mode not supported                           |
|       | 1 Ethernet mode supported                               |
| 11-13 | Reserved                                                |
| 14    | 0 Can be configured to run in Ethernet normal/full mode |
|       | 1 Ethernet normal/full mode off                         |
| 15    | 0 Can be configured to run in Ethernet reduced mode     |
|       | 1 Ethernet reduced mode off                             |

Address: Base address + 4h offset



<sup>\*</sup> Notes:

 $\bullet~$  TSEC\_INT field: n depends on the modes supported by the device.

#### eTSECx\_TSEC\_ID2 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>-          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                    |
| 8-15<br>TSEC_INT  | Interface mode support. See the table above for settings.                                                                                                                                                                                                                                                                                                           |
| 16–23<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                    |
| 24–31<br>TSEC_CFG | Value identifies configuration options of the eTSEC.  00 eTSEC multiple ring, Rx TOE, Filer and Tx TOE supports are off F0 eTSEC multiple ring, Rx TOE, Filer and Tx TOE supports are on 30 eTSEC multiple ring support is OFF and Rx TOE, Filer and Tx TOE supports are on 50 eTSEC multiple ring and filer supports are OFF and Rx TOE and Tx TOE supports are on |

#### 15.5.4 Group Interrupt event register (eTSECx\_IEVENTGn)

Group interrupt events cause bits in the IEVENTG g register to be set. This register is unique per group. Software may poll this register at any time to check for pending interrupts. If an event occurs and is not masked (its corresponding enable bit is set in the interrupt mask register (IMASKG g), and either the event is specific to group g (per-ring events) or it is mapped via EMAPG to the current group), the event also causes a hardware interrupt at the PIC. A bit in the interrupt event register is cleared by writing a 1 to that bit position. A write of 0 has no effect.

Each eTSEC can issue the following kinds of hardware interrupt to the PIC:

- 1. Transmit interrupts for group *g* -issued whenever bits TXB or TXF of IEVENTG *g* are set to 1 and either transmit interrupt coalescing is disabled or the interrupt coalescing thresholds have been met. To negate this hardware interrupt, software must clear both TXB and TXF bits.
- 2. Receive interrupts for group *g* -issued whenever bits RXB or RXF or FGPI of IEVENTG *g* are set to 1 and either receive interrupt coalescing is disabled or the interrupt coalescing thresholds have been met. To negate this hardware interrupt, software must clear both RXB and RXF bits.
- 3. Error and diagnostic interrupts for group *g* -issued whenever bits MAG, GTSC, GRSC, TXC, RXC, BABR, BABT, LC, CRL, FIR, FIQ, DPE, PERR, EBERR, XFUN, TWK, MSRO, BSY of IEVENTG *g* are set to 1. Software must clear all of these bits to negate an error/diagnostic hardware interrupt.
  - Magic Packet reception event is: MAG
  - Operational diagnostics are events on: GTSC, GRSC, TXC and RXC
  - Interrupts resulting from errors/problems detected in the network or transceiver are: BABR, BABT, LC and CRL

#### eTSEC memory map/register definition

- Interrupts resulting from internal errors are: FIR, FIQ, DPE, PERR, EBERR, XFUN and BSY
- Each error/diagnostic event except BSY is mappable to any group based on register EMAPG at offset 0x01C.
- BSY is mapped to the group corresponding to the ring detecting the event. See Interrupt steering register group n (eTSEC\_ISRGn) for more detail.

Some of the error interrupts are independently counted in the MIB block counters. Software may choose to mask off these interrupts because these errors are visible to network management through the MIB counters.





#### eTSECx\_IEVENTGn field descriptions

| Field      | Description                                                                                                                                                                                                        |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>BABR  | Babbling receive error . This bit indicates that a frame was received with length in excess of the MAC's maximum frame length register while MACCFG2[Huge_Frame] is set.                                           |
|            | 0 Excessive frame not received                                                                                                                                                                                     |
|            | 1 Excessive frame received                                                                                                                                                                                         |
| 1<br>RXC   | Receive control interrupt . A control frame was received while MACCFG1[Rx_Flow] is set . As soon as the transmitter finishes sending the current frame, a pause operation is performed.                            |
|            | 0 Control frame not received                                                                                                                                                                                       |
|            | 1 Control frame received                                                                                                                                                                                           |
| 2<br>BSY   | Busy condition interrupt . Indicates that a frame was received and discarded due to a lack of buffers.                                                                                                             |
|            | 0 No frame received and discarded                                                                                                                                                                                  |
|            | 1 Frame received and discarded                                                                                                                                                                                     |
| 3<br>EBERR | Internal bus error . This bit indicates that a system bus error occurred while a DMA transaction was underway . As a result, transferred data is expected to be partially or completely invalid.                   |
|            | 0 No system bus error occurred                                                                                                                                                                                     |
|            | 1 System bus error occurred                                                                                                                                                                                        |
| 4 -        | This field is reserved. Reserved                                                                                                                                                                                   |
| 5<br>MSRO  | MIB counter overflow . This interrupt is asserted if the count for one of the MIB counters has exceeded the size of its register.                                                                                  |
|            | 0 MIB count not exceeding its register size                                                                                                                                                                        |
|            | 1 MIB count exceeds its register size                                                                                                                                                                              |
| 6<br>GTSC  | Graceful transmit stop complete . This interrupt is asserted for one of two reasons. Graceful stop means that the transmitter is put into a pause state after completion of the frame currently being transmitted. |

# eTSECx\_IEVENTGn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <ul> <li>A graceful stop, which was initiated by setting DMACTRL[GTS], is now complete.</li> <li>A transmission of a flow control PAUSE frame, which was initiated by setting TCTRL[TFC_PAUSE], is now complete.</li> </ul>                                                                                                                                                                                                                                                                                                                           |
|               | No graceful stop interrupt     Graceful stop requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7<br>BABT     | Babbling transmit error . This bit indicates that the transmitted frame length has exceeded the value in the MAC's maximum frame length register and MACCFG2[Huge_Frame] is cleared . Frame truncation occurs when this condition occurs.                                                                                                                                                                                                                                                                                                             |
|               | Transmitted frame length not exceeding maximum frame length     Transmitted frame length exceeding maximum frame length when MACCFG2[Huge_Frame] = 0                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8             | Transmit control interrupt . This bit indicates that a control frame was transmitted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TXC           | 0 Control frame not transmitted 1 Control frame transmitted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9 -           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10<br>TXB     | Transmit buffer . This bit indicates that a transmit buffer descriptor was updated whose I (interrupt) bit was set in its status word and was not the last buffer descriptor of the frame.                                                                                                                                                                                                                                                                                                                                                            |
|               | No transmit buffer descriptor updated     Transmit buffer descriptor updated                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11<br>TXF     | Transmit frame interrupt . This bit indicates that a frame was transmitted and that the last corresponding transmit buffer descriptor (TxBD) was updated . This only occurs if the I (interrupt) bit in the status word of the buffer descriptor is set. The specific transmit queue that was updated has its TXF bit set in TSTAT $n$ . If transmit interrupt coalescing is enabled, this bit is set only if the requirements for transmit coalescing interrupt are met. See Transmit interrupt coalescing register (eTSEC_TXIC) , for more details. |
|               | No frame transmitted/TxBD not updated     Frame transmitted/TxBD updated                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 12            | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 13<br>LC      | Late collision . This bit indicates that a collision occurred beyond the collision window (slot time) in half-duplex mode . The frame is truncated with a bad CRC and the remainder of the frame is discarded.                                                                                                                                                                                                                                                                                                                                        |
|               | No late collision occurred     Late collision occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14<br>CRL_EXD | Collision retry limit . This bit indicates that the number of successive transmission collisions has exceeded the MAC's half-duplex register's retransmission maximum count (HAFDUP[Retransmission_Maximum]) . The frame is discarded without being transmitted and the queue halts (TSTAT[THLT $n$ ] set to 1). This only occurs while in half-duplex mode.                                                                                                                                                                                          |
|               | 0 Successive transmission collisions do not exceed maximum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               | 1 Successive transmission collisions exceed maximum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | Excessive defer . This bit indicates that a transmitted frame has been aborted due to excessive defer condition on the bus (HAFDUP[Excessive Defer] = 0) . The frame is discarded without being transmitted and transmission of the next frame commences.                                                                                                                                                                                                                                                                                             |
|               | 0 No excessive defer condition seen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | 1 Excessive defer condition seen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## eTSECx\_IEVENTGn field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 15<br>XFUN | Transmit FIFO underrun . This bit indicates that the transmit FIFO became empty before the complete frame was transmitted.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|            | Transmit FIFO not underrun     Transmit FIFO underrun                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 16<br>RXB  | Receive buffer . This bit indicates that a receive buffer descriptor was updated which had the I (Interrupt) bit set in its status word and was not the last buffer descriptor of the frame.                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|            | <ul><li>0 Receive buffer descriptor not updated</li><li>1 Receiver buffer descriptor updated</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 17–18<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 19<br>TWK  | Timer wakeup. This bit indicates that either a frame was accepted and written to memory while eTSEC is in sleep mode or the number of free RxBD is equal to or less than the threshold value while in LFC mode (RCTRL[LFC] = 1) and eTSEC is in sleep mode.                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|            | 0 No wakeup timer event detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|            | 1 Wakeup timer event detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 20<br>MAG  | Magic Packet detected when the eTSEC is in Magic Packet detection mode (MACCFG2[MPEN] = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|            | <ul> <li>No Magic Packet received or Magic Packet mode was not enabled</li> <li>A Magic Packet was received while in Magic Packet mode. MACCFG2[MPEN] is also cleared upon</li> </ul>                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|            | receiving the Magic Packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 21–22<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 23<br>GRSC | Graceful receive stop complete. This interrupt is asserted if a graceful receive stop is completed. It allows the user to know if the system has completed the stop and it is safe to write to receive registers (status, control or configuration registers) that are used by the system during normal operation.                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|            | 0 Graceful stop not completed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|            | 1 Graceful stop completed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| 24<br>RXF  | Receive frame interrupt . This bit indicates that a frame was received and the last receive buffer descriptor (RxBD) in that frame was updated . This occurs either if the I (interrupt) bit in the buffer descriptor status word is set, or an overrun error occurs. The specific receive queue that was updated has its RXF bit set in RSTATn. If receive interrupt coalescing is enabled, this bit is set only if the requirements for receive coalescing interrupt are met. See Ring n Rx interrupt coalescing (eTSEC_RXICn), for more details. |  |  |  |  |  |  |
|            | 0 Frame not received                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| 25.00      | 1 Frame received                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 25–26<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 27<br>FGPI | Filer generated general purpose interrupt on a set of filer rule match. This bit will be set upon reception of a frame that matches a GPI rule sequence that is specified in the filer. It is synchronized with the setting of RXF.                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|            | No filer generated interrupt has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|            | 1 The filer has accepted a frame via a matching rule that the RQFCR[GPI] bit set .                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 28<br>FIR  | The receive queue filer result is invalid, either because not enough time between frames was available to find a matching rule, or no entry in the filer table could be matched.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |

#### eTSEC memory map/register definition

## eTSECx\_IEVENTGn field descriptions (continued)

| Field      | Description                                                                                                                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0 Receive queue filer reached a definite result; however, bit FIQ may still be set if a frame was filed to a disabled RxBD ring.                                                                           |
|            | 1 Receive queue filer was unable to reach a definite result. In this case, bit FIQ is also set if no entry in the filer table could provide a rule match.                                                  |
| 29<br>FIQ  | Filed frame to invalid receive queue . This bit indicates that either the receive queue filer chose to DMA a received frame to a disabled RxBD ring, or that no rule in the filer table could be matched . |
|            | O Received frames filed to valid queues or rejected. Note that a frame may be rejected if the filer has insufficient time to reach a conclusive result between frames, in which case bit FIR is set.       |
|            | 1 Received frames filed to RxBD rings that are not enabled. The frame is discarded. If bit FIR is also set this indicates that the filer exhausted all of its table entries without a rule match.          |
| 30<br>DPE  | Internal data parity error . This bit indicates that the eTSEC has detected a parity error on its stored data, which is likely to compromise the validity of recently transferred frames .                 |
|            | 0 No parity errors detected.                                                                                                                                                                               |
|            | 1 Data held in the FIFO or filer arrays is expected to be corrupted due to a parity error.                                                                                                                 |
| 31<br>PERR | Receive frame parse error for TCP/IP offload . This bit indicates that a received frame could not be parsed unambiguously, due to encapsulated header type fields contradicting each other .               |
|            | 0 Received frame parsed successfully.                                                                                                                                                                      |
|            | 1 Received frame parse revealed header inconsistencies.                                                                                                                                                    |

## 15.5.5 Group Interrupt mask register (eTSECx\_IMASKGn)

The group interrupt mask register provides control over which possible interrupt events in the IEVENTG g register are permitted to participate in generating hardware interrupts to the PIC. All implemented bits in this register are R/W and cleared upon a hardware reset. If the corresponding bits in both the IEVENTG g and IMASKG g registers are set, and either the interrupt is not mappable via EMAPG, or the corresponding field in EMAPG is set to group g, the PIC receives an interrupt (for each eTSEC these are grouped into transmit, receive, and error/diagnostic interrupts). The interrupt signal remains asserted until either the IEVENTG g bit is cleared, by writing a 1 to it, or by writing a 0 to the corresponding IMASKG g bit.



eTSECx\_IMASKGn field descriptions

| Field      | Description                        |
|------------|------------------------------------|
| 0<br>BREN  | Babbling receiver interrupt enable |
| 1<br>RXCEN | Receive control interrupt enable   |

#### eTSEC memory map/register definition

## eTSECx\_IMASKGn field descriptions (continued)

| Field        | Description                                      |
|--------------|--------------------------------------------------|
| 2<br>BSYEN   | Busy interrupt enable                            |
| 3<br>EBERREN | Ethernet controller bus error enable             |
| 4 -          | This field is reserved. Reserved                 |
| 5<br>MSROEN  | MIB counter overflow interrupt enable            |
| 6<br>GTSCEN  | Graceful transmit stop complete interrupt enable |
| 7<br>BTEN    | Babbling transmitter interrupt enable            |
| 8<br>TXCEN   | Transmit control interrupt enable                |
| 9 -          | This field is reserved. Reserved                 |
| 10<br>TXBEN  | Transmit buffer interrupt enable                 |
| 11<br>TXFEN  | Transmit frame interrupt enable                  |
| 12<br>-      | This field is reserved. Reserved                 |
| 13<br>LCEN   | Late collision enable                            |
| 14<br>CRLEN  | Collision retry limit enable                     |
| 15<br>XFUNEN | Transmit FIFO underrun enable                    |
| 16<br>RXBEN  | Receive buffer interrupt enable                  |
| 17–18<br>-   | This field is reserved. Reserved                 |
| 19<br>TWKEN  | Timer wakeup event enable                        |
| 20<br>MAGEN  | Magic packet received interrupt enable           |
| 21–22<br>-   | This field is reserved. Reserved                 |
| 23<br>GRSCEN | Graceful receive stop complete interrupt enable  |
| 24<br>RXFEN  | Receive frame interrupt enable                   |
| 25–26<br>-   | This field is reserved. Reserved                 |
| 27<br>FGPIEN | Filer general purpose interrupt enable           |

#### eTSECx\_IMASKGn field descriptions (continued)

| Field        | Description                                   |
|--------------|-----------------------------------------------|
| 28<br>FIREN  | Filer invalid result interrupt enable         |
| 29<br>FIQEN  | Filed frame to invalid queue interrupt enable |
| 30<br>DPEEN  | Data parity error interrupt enable            |
| 31<br>PERREN | Receive frame parse error enable              |

## 15.5.6 Error disabled register (eTSECx\_EDIS)

The error disabled register allows the user to disable an error interruption, possibly to avoid spurious error indications external to the eTSECs.



#### eTSECx\_EDIS field descriptions

| Field         | Description                                                                                                                                                                                                                                             |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0–1<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                        |  |  |  |  |  |
| 2<br>BSYDIS   | <ul> <li>Busy disable.</li> <li>Allow eTSEC to report IEVENTG g [BSY] status and halt buffer descriptor queue if BSY condition occurs.</li> <li>Do not set IEVENTG g [BSY] and do not halt buffer descriptor queue if BSY condition occurs .</li> </ul> |  |  |  |  |  |
| 3<br>EBERRDIS | Ethernet controller bus error disable.                                                                                                                                                                                                                  |  |  |  |  |  |

## eTSECx\_EDIS field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | Allow eTSEC to report IEVENTG g [EBERR] status and halt buffer descriptor queue if EBERR condition occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|               | 1 Do not set IEVENTG $g$ [EBERR] and do not halt buffer descriptor queue if EBERR condition occurs .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4–6           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7<br>BABTDIS  | Babbling transmit error disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| BABTUIS       | <ul> <li>Allow eTSEC to report IEVENTG g [BABT] status and set the buffer descriptor TR field.</li> <li>Do not set IEVENTG g [BABT] nor the buffer descriptor TR field.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8–12<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13<br>LCDIS   | Late collision disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| LODIS         | O Allow eTSEC to report IEVENTG g [LC] status, set the buffer descriptor LC field, and halt buffer descriptor queue if LC condition occurs. 1. Provide the IEVENTO of ICO and the buffer descriptor LC field and the IEVENTO of ICO and the buffer descriptor LC field and the IEVENTO of ICO and the buffer descriptor LC field and the IEVENTO of ICO and the buffer descriptor LC field and the IEVENTO of ICO and IEVENTO of ICO |
|               | 1 Do not set IEVENTG $g$ [LC] nor the buffer descriptor LC field, and do not halt buffer descriptor queue if LC condition occurs .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14<br>CRLDIS  | Collision retry limit disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | O Allow eTSEC to report IEVENTG g [CRL] status, set the buffer descriptor RL field, and halt buffer<br>descriptor queue if CRL condition occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | 1 Do not set IEVENTG $g$ [CRL] nor the buffer descriptor RL field, and do not halt buffer descriptor queue if CRL condition occurs .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15<br>XFUNDIS | Transmit FIFO underrun disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7.1. 011210   | O Allow eTSEC to report IEVENTG g [XFUN] status, set the buffer descriptor UN field, and halt buffer<br>descriptor queue if XFUN condition occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | 1 Do not set IEVENTG $g$ [XFUN] nor the buffer descriptor UN field, and do not halt buffer descriptor queue if XFUN condition occurs .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16–27         | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 28            | Reserved Filer invalid result error disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FIRDIS        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | <ul> <li>Allow eTSEC to report IEVENTG g [FIR] status.</li> <li>Do not set IEVENTG g [FIR] if eTSEC fails to reach a definite filer result when attempting to file a</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | received frame, but discard the frame silently.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 29<br>FIQDIS  | Filed frame to invalid queue error disable .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | <ul> <li>Allow eTSEC to report IEVENTG g [FIQ] status.</li> <li>Do not set IEVENTG g [FIQ] if eTSEC attempts to file a received frame to an invalid (disabled) RxBD</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | ring, but discard the frame silently.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30<br>DPEDIS  | Data parity error disable .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | <ul> <li>Allow eTSEC to report IEVENTG g [DPE] status.</li> <li>Do not set IEVENTG g [DPE] if a parity error occurs in eTSEC's FIFO or filer arrays .</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31            | Receive frame parse error disable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PERRDIS       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | <ul> <li>Allow eTSEC to report IEVENTG g [PERR] status.</li> <li>Do not set IEVENTG g [PERR] if a parse error occurs on a received frame .</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | . To the contract of grant and a parison of a reconstruct matter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# 15.5.7 Group Error mapping register (eTSECx\_EMAPG)

The error mapping register allows the user to route errors to a particular group error interrupt.

| Address: Base address + 1Ch offs | set |
|----------------------------------|-----|
|----------------------------------|-----|

| Bit    | 0       | 1   | 2     | 3   | 4       | 5   | 6      | 7   | 8      | 9     | 10     | 11  | 12    | 13  | 14   | 15  |
|--------|---------|-----|-------|-----|---------|-----|--------|-----|--------|-------|--------|-----|-------|-----|------|-----|
| R<br>W | RVRRIED |     | RXCGP |     | EBERRGP |     | MSROGP |     | GTSCGP |       | BABTGP |     | TXCGP |     | LCGP |     |
| Reset  | 0       | 0   | 0     | 0   | 0       | 0   | 0      | 0   | 0      | 0     | 0      | 0   | 0     | 0   | 0    | 0   |
| Bit    | 16      | 17  | 18    | 19  | 20      | 21  | 22     | 23  | 24     | 25    | 26     | 27  | 28    | 29  | 30   | 31  |
| R      | 0.01    | 0.0 |       |     | MAG     | iGP | 0.00   | 000 |        | 0.0   |        | 0.0 |       | -00 | 555  | 505 |
| w      | CRLGP   |     | XFU   | NGP | TWI     | _   | GRS    | CGP | FIR    | IGP . | FIG    | GP  | DPE   | :GP | PER  | RGP |
| Reset  | 0       | 0   | 0     | 0   | 0       | 0   | 0      | 0   | 0      | 0     | 0      | 0   | 0     | 0   | 0    | 0   |

#### eTSECx\_EMAPG field descriptions

| Field          | Description                                     |  |  |  |  |  |  |
|----------------|-------------------------------------------------|--|--|--|--|--|--|
| 0–1<br>BABRGP  | Babbling receiver interrupt group mapping.      |  |  |  |  |  |  |
|                | 00 Map to group 0                               |  |  |  |  |  |  |
|                | 01 ReservedMap to group 1                       |  |  |  |  |  |  |
|                | 10 Reserved                                     |  |  |  |  |  |  |
|                | 1 Reserved                                      |  |  |  |  |  |  |
| 2–3<br>RXCGP   | Receive control interrupt group mapping.        |  |  |  |  |  |  |
|                | 00 Map to group 0                               |  |  |  |  |  |  |
|                | 01 ReservedMap to group 1                       |  |  |  |  |  |  |
|                | 10 Reserved                                     |  |  |  |  |  |  |
|                | 11 Reserved                                     |  |  |  |  |  |  |
| 4–5<br>EBERRGP | Internal bus error interrupt group mapping.     |  |  |  |  |  |  |
|                | 00 Map to group 0                               |  |  |  |  |  |  |
|                | 01 ReservedMap to group 1                       |  |  |  |  |  |  |
|                | 10 Reserved                                     |  |  |  |  |  |  |
|                | 11 Reserved                                     |  |  |  |  |  |  |
| 6–7<br>MSROGP  | MIB counter overflow interrupt group mapping.   |  |  |  |  |  |  |
|                | 00 Map to group 0                               |  |  |  |  |  |  |
|                | 01 ReservedMap to group 1                       |  |  |  |  |  |  |
|                | 10 Reserved                                     |  |  |  |  |  |  |
|                | 11 Reserved                                     |  |  |  |  |  |  |
| 8–9<br>GTSCGP  | Graceful Transmit Stop interrupt group mapping. |  |  |  |  |  |  |
|                | 00 Map to group 0                               |  |  |  |  |  |  |
|                | 01 ReservedMap to group 1                       |  |  |  |  |  |  |

## eTSECx\_EMAPG field descriptions (continued)

| Field           | Description                                                     |
|-----------------|-----------------------------------------------------------------|
|                 | 10 Reserved                                                     |
|                 | 11 Reserved                                                     |
| 10–11           | Babling transmit interrupt group mapping.                       |
| BABTGP          |                                                                 |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | 10 Reserved 11 Reserved                                         |
|                 |                                                                 |
| 12–13<br>TXCGP  | Transmit control interrupt group mapping.                       |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | <ul><li>10 Reserved</li><li>11 Reserved</li></ul>               |
| 44.45           |                                                                 |
| 14–15<br>LCGP   | Late collision interrupt group mapping.                         |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | 10 Reserved 11 Reserved                                         |
| 16–17           | Collision retry limit interrupt group mapping.                  |
| CRLGP           | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | 10 Reserved                                                     |
|                 | 11 Reserved                                                     |
| 18–19           | Transmit underrun interrupt group mapping.                      |
| XFUNGP          | OO. Man to group O                                              |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1 10 Reserved                           |
|                 | 11 Reserved                                                     |
| 20–21           |                                                                 |
| MAGGP_TWKTP     | Magic packet received and wakeup timer interrupt group mapping. |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | 10 Reserved                                                     |
|                 | 11 Reserved                                                     |
| 22–23<br>GRSCGP | Graceful Receive Stop interrupt group mapping.                  |
|                 | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
|                 | 10 Reserved                                                     |
|                 | 11 Reserved                                                     |
| 24–25           | Filer Result error interrupt group mapping.                     |
| FIRGP           | 00 Map to group 0                                               |
|                 | 01 ReservedMap to group 1                                       |
| I               | o                                                               |

#### eTSECx\_EMAPG field descriptions (continued)

| Field           | Description                                        |  |  |  |  |  |
|-----------------|----------------------------------------------------|--|--|--|--|--|
|                 | 10 Reserved                                        |  |  |  |  |  |
|                 | 11 Reserved                                        |  |  |  |  |  |
| 26–27<br>FIQGP  | Filer Queue error interrupt group mapping.         |  |  |  |  |  |
|                 | 00 Map to group 0                                  |  |  |  |  |  |
|                 | 01 ReservedMap to group 1                          |  |  |  |  |  |
|                 | 10 Reserved                                        |  |  |  |  |  |
|                 | 11 Reserved                                        |  |  |  |  |  |
| 28–29<br>DPEGP  | Internal Data error interrupt group mapping.       |  |  |  |  |  |
|                 | 00 Map to group 0                                  |  |  |  |  |  |
|                 | 01 ReservedMap to group 1                          |  |  |  |  |  |
|                 | 10 Reserved                                        |  |  |  |  |  |
|                 | 11 Reserved                                        |  |  |  |  |  |
| 30–31<br>PERRGP | Receive frame parse error interrupt group mapping. |  |  |  |  |  |
|                 | 00 Map to group 0                                  |  |  |  |  |  |
|                 | 01 ReservedMap to group 1                          |  |  |  |  |  |
|                 | 10 Reserved                                        |  |  |  |  |  |
|                 | 11 Reserved                                        |  |  |  |  |  |

## 15.5.8 Ethernet control register (eTSECx\_ECNTRL)

ECNTRL is a register writable by the user to reset, configure, and initialize the eTSEC. Note that the FIFM, GMIIM, TBIM, RMM, and RPM fields are read-only, having been set after sampling signals at power-on-reset.

The different interface configurations indicated by registers ECNTRL and MACCFG2 are summarized in the table below.

Table 15-255. eTSEC Interface Configurations

| Interface Mode  | ECNTRL Field      |                    |      |     | MACCFG2 Field |     |        |          |
|-----------------|-------------------|--------------------|------|-----|---------------|-----|--------|----------|
|                 | FIFM <sup>1</sup> | GMIIM <sup>2</sup> | TBIM | RPM | R100M         | RMM | SGMIIM | I/F Mode |
| MII 10/100 Mbps | 0                 | 0                  | 0    | 0   | 0             | 0   | 0      | 01       |
| RMII 100 Mbps   | 0                 | 0                  | 0    | 0   | 1             | 1   | 0      | 01       |
| RMII 10 Mbps    | 0                 | 0                  | 0    | 0   | 0             | 1   | 0      | 01       |
| RGMII 1Gbps     | 0                 | 1                  | 0    | 1   | 0             | 0   | 0      | 10       |
| RGMII 100 Mbps  | 0                 | 1                  | 0    | 1   | 1             | 0   | 0      | 01       |
| RGMII 10 Mbps   | 0                 | 1                  | 0    | 1   | 0             | 0   | 0      | 01       |
| SGMII 1 Gbps    | 0                 | 0                  | 1    | 0   | 0             | 0   | 1      | 10       |
| SGMII 100 Mbps  | 0                 | 0                  | 1    | 0   | 1             | 0   | 1      | 01       |
| SGMII 10 Mbps   | 0                 | 0                  | 1    | 0   | 0             | 0   | 1      | 01       |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### eTSEC memory map/register definition

- 1. FIFM bit is not supported.
- 2. GMIIM bit is not supported.

Address: Base address + 20h offset





#### eTSECx\_ECNTRL field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 16<br>FIFM   | FIFO mode. Not supported.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17<br>CLRCNT | Clear all statistics counters and carry registers.  This bit is self-resetting.  O Allow MIB counters to continue to increment and keep any overflow indicators.  Reset all MIB counters and CAR1 and CAR2.                                                                                                                                                                                                                |
| 18<br>AUTOZ  | Automatically zero MIB counter values and carry registers.  This is a steady state signal and must be set prior to enabling the Ethernet controller and may cause indeterminate values in the statistics counters if changed while MACCFG1[Rx_En] or [Tx_En] is set.  O The user must write the addressed counter zero after a host read.  The addressed counter value is automatically cleared to zero after a host read. |
| 19<br>STEN   | MIB counter statistics enabled .  This is a steady state signal and must be set prior to enabling the Ethernet controller may cause indeterminate values in the statistics counters if changed while MACCFG1[Rx_En] or [Tx_En] is set                                                                                                                                                                                      |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### eTSEC memory map/register definition

# eTSECx\_ECNTRL field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0 Statistics not enabled                                                                                                                                                                                                                                                                            |
|              | 1 Enables internal counters to update                                                                                                                                                                                                                                                               |
| 20–24        | This field is reserved. Reserved                                                                                                                                                                                                                                                                    |
| 25<br>GMIIM  | GMII interface mode. Not supported.                                                                                                                                                                                                                                                                 |
| 26<br>TBIM   | TBI mode . If this bit is set, ten-bit interface mode is enabled. See the table above for detailed settings. This bit can be pin-configured at reset to set or clear . See Power-on reset configuration .                                                                                           |
|              | 0 Reserved                                                                                                                                                                                                                                                                                          |
|              | 1 Ten-bit mode interface                                                                                                                                                                                                                                                                            |
| 27<br>RPM    | Reduced-pin mode for Gigabit interfaces. If this bit is set, a reduced-pin interface is expected on Ethernet interfaces. RPM and RMM are never set together. See the table above for detailed settings. This register can be pin-configured at reset to 0 or 1 . See Power-on reset configuration . |
|              | <ul> <li>Gigabit interface in non reduced-pin mode configuration or non-gigabit interface</li> <li>Gigabit interface in reduced-pin modes</li> </ul>                                                                                                                                                |
| 28<br>R100M  | RGMII /RMII 100 mode. This bit is ignored unless SGMIIM, RPM or RMM are set and MACCFG2[I/F Mode] is assigned to 10/100 (01). See the table above for detailed settings.                                                                                                                            |
|              | This bit must be cleared for 1-Gbps SGMII operation.                                                                                                                                                                                                                                                |
|              | 0 RGMII is in 10 Mbps mode                                                                                                                                                                                                                                                                          |
|              | RMII is in 10 Mbps mode, and every 10th RMII Reference clock is used to transfer data                                                                                                                                                                                                               |
|              | SGMII is in 10 Mbps mode, and every 100th SGMII Reference clock is used to transfer data                                                                                                                                                                                                            |
|              | 1 RGMII is in 100 Mbps mode                                                                                                                                                                                                                                                                         |
|              | RMII is in 100 Mbps mode, and data is transferred on every Reference clock                                                                                                                                                                                                                          |
|              | SGMII is in 100 Mbps mode, and every 10th SGMII Reference clock is used to transfer data                                                                                                                                                                                                            |
| 29<br>RMM    | Reduced-pin mode for 10/100 interfaces. If this bit is set, an RMII pin interface is expected. RMM must be 0 if RPM = 1. See the table above for detailed settings. This register can be pin-configured at reset to 0 or 1 . See Power-on reset configuration .                                     |
|              | 0 Non-RMII interface mode                                                                                                                                                                                                                                                                           |
|              | 1 RMII interface mode                                                                                                                                                                                                                                                                               |
| 30<br>SGMIIM | Serial GMII mode . If this bit is set, a SGMII pin interface is expected to be connected via an on chip SerDes.                                                                                                                                                                                     |
|              | This register can be pin-configured at reset to 0 or 1 . See Power-on reset configuration .                                                                                                                                                                                                         |
|              | 0 SGMII mode disabled. eTSEC connected via a parallel interface.                                                                                                                                                                                                                                    |
|              | 1 SGMII mode enabled.                                                                                                                                                                                                                                                                               |
| 31<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                    |

<sup>1.</sup> FIFM bit is not supported.

<sup>2.</sup> GMIIM bit is not supported.

## 15.5.9 Pause time value register (eTSECx\_PTV)

PTV is a 32-bit register written by the user to store the pause duration used when the eTSEC initiates an IEEE 802.3 PAUSE control frame through TCTRL[TFC\_PAUSE]. The low-order 16 bits (PT) represent the pause time and the high-order 16 bits (PTE) represent the extended pause control parameter. The pause time is measured in units of pause\_quanta, equal to 512 bit times. The pause time can range from 0 to 65,535 pause\_quanta, or 0 to 33,553,920 bit times. See Flow Control for additional details.





#### eTSECx\_PTV field descriptions

| Field | Description                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Extended pause control. This field allows software to add a 16-bit additional control parameter into the PAUSE frame to be sent when TCTRL[TFC_PAUSE] is set. Note that current IEEE 802.3 PAUSE frame format requires this parameter to be cleared. |
|       | Pause time value. Represents the 16-bit pause quanta (that is, 512 bit times). This pause value is used as part of the PAUSE frame to be sent when TCTRL[TFC_PAUSE] is set. See Flow control for more information.                                   |

# 15.5.10 DMA control register (eTSECx\_DMACTRL)

DMACTRL is writable by the user to configure the DMA block.



#### eTSECx\_DMACTRL field descriptions

| Field       | Description                                                                                                                                                                                                                                                             |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15        | This field is reserved.                                                                                                                                                                                                                                                 |
| -           | Reserved                                                                                                                                                                                                                                                                |
| 16<br>LE    | Little-endian descriptor mode enable. This bit controls both the reading and writing of descriptors; data buffers are always transferred in network byte order.                                                                                                         |
|             | 0 RxBDs and TxBDs are interpreted with big-endian byte ordering, as shown in Data buffer descriptors.                                                                                                                                                                   |
|             | 1 RxBDs and TxBDs are interpreted with little-endian byte ordering. That is, the 16 bits of flags are considered a complete half-word unit, the buffer length is considered another complete half-word unit, and the buffer pointer is considered a complete word unit. |
| 17–23       | This field is reserved.                                                                                                                                                                                                                                                 |
| -           | Reserved                                                                                                                                                                                                                                                                |
| 24<br>TDSEN | Tx Data snoop enable.                                                                                                                                                                                                                                                   |
|             | 0 Disables snooping of all transmit frames from memory .                                                                                                                                                                                                                |
|             | 1 Enables snooping of all transmit frames from memory .                                                                                                                                                                                                                 |

## eTSECx\_DMACTRL field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>TDD 05N | TxBD snoop enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TBDSEN        | 0 Disables snooping of all transmit BD memory accesses .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 1 Enables snooping of all transmit BD memory accesses .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 26<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27<br>GRS     | Graceful receive stop . If this bit is set, the Ethernet controller stops receiving frames following completion of the frame currently being received . (That is, after a valid end of frame was received) . The contents of the Rx FIFO are then written to memory, and the IEVENTG $g$ [GRSC] is set to indicate that all current receive buffers have been closed . Because the receive enable bit of the MAC may still be set, the MAC may continue to receive but the eTSEC ignores the receive data until GRS is cleared . If this bit is cleared, the eTSEC scans the input data stream for the start of a new frame (preamble sequence and start of frame delimiter) and the first valid frame received uses the next RxBD . |
|               | If GRS is set, the user must monitor the graceful receive stop complete (GRSC) bit in the IEVENTG $g$ register to insure that the graceful receive stop was completed. The user can then clear IEVENTG $g$ [GRSC] and can write to receive registers that are accessible to both user and the eTSEC hardware without fear of conflict.                                                                                                                                                                                                                                                                                                                                                                                               |
|               | 0 eTSEC scans input data stream for valid frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | 1 eTSEC stops receiving frames following completion of current frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28<br>GTS     | Graceful transmit stop . If this bit is set, the Ethernet controller stops transmission after all frames that are currently in the Tx FIFO or scheduled have been transmitted, and the GTSC interrupt in the IEVENTG $g$ register is asserted . A frame that has started reading buffer descriptors or data from memory is read to completion and transmitted before the GTSC interrupt occurs. However, if no frame has been scheduled for transmission and the Tx FIFO is empty, the GTSC interrupt is asserted immediately . Once transmission has completed, clearing GTS "restart" transmit.                                                                                                                                    |
|               | 0 Controller continues.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | 1 Controller stops transmission after completion of current frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 29<br>TOD     | Transmit on demand for TxBD ring 0. This bit is applicable only to the transmitter, and requires both TCTRL[TXSCHED] = 00 and DMACTRL[WOP] = 0. If 1 is written to this bit, the eTSEC immediately begins fetching the next TxBD from ring 0, avoiding waiting the normal polling time to check the TxBD's R bit. This bit is always read as 0.                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 0 eTSEC continues waiting for the TxBD ring 0 poll timer to expire.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | 1 eTSEC immediately fetches a new TxBD from ring 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 30<br>WWR     | Write with response . This bit gives the user the assurance that a BD was updated in memory before it receives an interrupt concerning a transmit or receive frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | 0 Do not wait for acknowledgement from system for BD writes before setting IEVENTG $g$ bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | 1 Before setting IEVENTG <i>g</i> bits TXB, TXF, XFUN, LC, CRL, RXB, RXF, the eTSEC waits for acknowledgement from system that the transmit or receive BD being updated was stored in memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31<br>WOP     | Wait or poll for TxBD ring 0 . This bit, which is applicable only to the transmitter and when TCTRL[TXSCHED] = 00, provides the user the option for the eTSEC to periodically poll TxBDs or to wait for software to tell eTSEC to fetch a buffer descriptor . While operating in the "Wait" mode, the eTSEC allows two additional reads of a descriptor which is not ready before entering a halt state . No interrupt is driven . To resume transmission, software must clear TSTAT n [THLT0].                                                                                                                                                                                                                                      |
|               | 0 Poll TxBD on ring 0 every 512 serial clocks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | 1 Do not poll, but wait for TSTAT <i>n</i> [THLT0] to be cleared by the user.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## 15.5.11 TBI PHY address register (eTSECx\_TBIPA)

The TBIPA is writable by the user to assign a physical address to the TBI for MII management configuration. The TBI registers are accessed at the offset of TBIPA. For detailed descriptions of the TBI registers (the MII register set for the ten-bit interface), refer to Ten-bit interface (TBI).





#### eTSECx\_TBIPA field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                         |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–26<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                    |
| 27–31<br>TBIPA | This field is used to program the PHY address of the ten-bit interface's MII management bus . To access the TBI register the user must write the TBIPA value to the MIIMADD [PHY Address] register located in the MAC register section . PHY Address 0 is reserved. Refer to MII management address register (eTSEC_MDIO_MIIMADD) . |

## 15.5.12 Transmit control register (eTSECx\_TCTRL)

This register is writable by the user to configure the transmit block.

#### NOTE

Except for TFC\_PAUSE and THDF, which may be updated onthe-fly, no TCTRL field values should be upated without a GTSC (graceful transmit stop complete).



Reset

## eTSECx\_TCTRL field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>-        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17<br>IPCSEN     | IP header checksum generation enable . When set, the eTSEC offloads IPv4 header checksum generation. See Transmit path off-load and Tx PTP packet parsing .                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | <ul> <li>IP header checksum generation is disabled even if enabled in a transmit frame control block.</li> <li>IP header checksum generation is performed for IPv4 headers as determined by the settings in the current transmit frame control block.</li> </ul>                                                                                                                                                                                                                                                                                                                                                      |
| 18<br>TUCSEN     | TCP/UDP header checksum generation enable . When set, the eTSEC offloads TCP or UDP header checksum generation. See Transmit path off-load and Tx PTP packet parsing .                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                  | TCP or UDP header checksum generation is disabled even if enabled in a transmit frame control block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | TCP or UDP header checksum generation is performed as determined by the settings in the current transmit frame control block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 19<br>VLINS      | VLAN (IEEE Std. 802.1Q) tag insertion enable . Applicable only for transmission through the Ethernet MAC .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 0 Do not insert a VLAN tag into the frame .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | 1 Insert a VLAN tag into the frame . If the frame FCB has a valid VLAN field, use the FCB to source the VLAN control word, otherwise take the default VLAN control word from register DFVLAN .                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 20<br>THDF       | Transmit half-duplex flow control under software control for 10-/100-Mbps half-duplex media . This bit is not self-resetting .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  | 0 Disable back pressure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                  | 1 Back pressure is applied to media by raising carrier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 21–26            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27<br>RFC_PAUSE  | Receive flow control pause frame (written by the eTSEC) . This read-only status bit is set if a flow control pause frame was received and the transmitter is paused for the duration defined in the received pause frame . This bit automatically clears after the pause duration is complete .                                                                                                                                                                                                                                                                                                                       |
|                  | 0 Pause duration complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 1 Flow control pause frame received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 28<br>TFC_PAUSE  | Transmit flow control pause frame. Set this bit to transmit a PAUSE frame . If this bit is set, the MAC stops transmission of data frames after the currently transmitting frame completes . Next, the MAC transmits a pause control frame with the duration value obtained from the PTV register . The TXC event occurs after sending the pause control frame. Finally, the controller clears TFC_PAUSE and resumes transmitting data frames as before. Note that pause control frames can still be transmitted if the Tx controller is stopped due to user assertion of DMACTRL[GTS] or reception of a PAUSE frame. |
|                  | No request for Tx PAUSE frame pending or transmission complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 00.00            | 1 Software request for Tx PAUSE frame pending.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29–30<br>TXSCHED | Transmit ring scheduling algorithm . This field determines which scheme the transmit scheduler uses to arbitrate between the enabled TxBD rings. The scheme chosen also controls how the DMACTRL and TQUEUE bits are interpreted. Ring polling is supported only by mode 00; the other modes require software to restart rings with the TSTAT $n$ register . TCP/IP offload can be enabled with any scheduling mode.                                                                                                                                                                                                  |
|                  | OO Single polled ring mode . TxBD ring 0 is the only ring serviced, even if other rings are enabled and ready . In this scheduler mode, the DMACTRL[WOP] and DMACTRL[TOD] bits control polling and                                                                                                                                                                                                                                                                                                                                                                                                                    |

## eTSECx\_TCTRL field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | retry behavior . This mode supports ring polling, and allows fetching of a non-ready TxBD to be retried twice.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|         | O1 Priority scheduling mode . All enabled TxBD rings are serviced in ascending ring index order . Once a non-ready TxBD has been fetched from the lowest-numbered ring, the eTSEC attempts to fetch TxBDs from the next enabled ring having a higher index, until transmission stops for lack of data . TSTAT <i>n</i> records whenever a TxBD ring is exhausted .                                                                                                                                                                                                                                                                                                                                                                          |
|         | <ul> <li>Modified weighted round-robin scheduling mode . Each TxBD ring is polled in sequence for frames that are ready for transmission . If a non-ready TxBD is fetched from a ring, that ring is removed from the scheduling pool until software re-enables it . Ready frames are repeatedly transmitted from a chosen ring until its transmission quota is exhausted . The transmission quota for TxBD ring n is set to WT n x 64 bytes, where WT n is a weight from the TR03WT/TR47WT registers . If a ring transmits more data than its quota allows, the excess is deducted from its quota on the next transmission opportunity, thereby preventing large frames from monopolizing the eTSEC bandwidth.</li> <li>Reserved</li> </ul> |
| 31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

## 15.5.13 Transmit status register (eTSECx\_TSTATn)

This register is read/write-one-to-clear and is written by the eTSEC to convey DMA status information for each TxBD ring that is assigned to group n. The halt bit only has meaning for enabled rings mapped to group n. After processing transmit-related interrupts, software should use TSTAT n to restart transmission from rings that may have been affected by the interrupt condition. In particular, an error condition that prevents eTSEC from continuing transmission halts DMA from all rings, including the ring that gave rise to the error.



eTSECx\_TSTATn field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>THLT0 | Transmit halt of ring 0. Set by the eTSEC if is no longer processing transmit frames from this TxBD ring and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be cleared by writing 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN0], or if no ready TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.     |
|            | Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error condition recurs and halts all queues again. Note that ISRGn[TR0] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept tx ring 0 interrupt before this bit can be set. |
|            | Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                               |
|            | Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                          |

## eTSECx\_TSTATn field descriptions (continued)

| <ul> <li>Invalid BD or data address</li> <li>Uncorrectable error on BD or data read</li> <li>TxBD programming errors:</li> <li>Ready = 1 and length = 0</li> <li>Transmit halt of ring 1 . Set by the eTSEC if is no longer processing transmit frames from this TxBI</li> </ul>                                                                                                                                                   |                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| TxBD programming errors:  • Ready = 1 and length = 0  1 Transmit halt of ring 1 . Set by the eTSEC if is no longer processing transmit frames from this TxBl                                                                                                                                                                                                                                                                       |                    |
| <ul> <li>Ready = 1 and length = 0</li> <li>Transmit halt of ring 1 . Set by the eTSEC if is no longer processing transmit frames from this TxBl</li> </ul>                                                                                                                                                                                                                                                                         |                    |
| 1 Transmit halt of ring 1 . Set by the eTSEC if is no longer processing transmit frames from this TxBl                                                                                                                                                                                                                                                                                                                             |                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                    |                    |
| THLT1 and DMA from this ring is disabled . To restart transmission from this TxBD ring, this bit must be cl by writing 1 to it . This bit is set only on a general error condition, regardless of TQUEUE[EN1], or ready TxBDs can be fetched . DMACTRL[GTS] being set by the user does not cause this bit to be                                                                                                                    | f no               |
| Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error correcurs and halts all queues again. Note that ISRGn[TR1] acts as an enabler of this bit when in mull mode. That is group $g$ must be programmed to accept Tx ring 1 interrupt before this bit can be set.             | ndition            |
| Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                              |                    |
| Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |
| <ul><li>Invalid BD or data address</li><li>Uncorrectable error on BD or data read</li></ul>                                                                                                                                                                                                                                                                                                                                        |                    |
| TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                           |                    |
| • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                         |                    |
| Transmit halt of ring 2 . Set by the eTSEC if is no longer processing transmit frames from this TxBl and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be clewriting 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN2], or if no TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.                      | ared by            |
| Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error converges recurs and halts all queues again. Note that ISRGn[TR2] acts as an enabler of this bit when in multimode. That is group <i>g</i> must be programmed to accept Tx ring 2 interrupt before this bit can be set. | ndition<br>tigroup |
| Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                              |                    |
| Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |
| <ul><li>Invalid BD or data address</li><li>Uncorrectable error on BD or data read</li></ul>                                                                                                                                                                                                                                                                                                                                        |                    |
| TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                           |                    |
| Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                           |                    |
| Transmit halt of ring 3 . Set by the eTSEC if is no longer processing transmit frames from this TxBl and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be clewriting 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN3], or if no TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.                      | ared by            |
| Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error corecurs and halts all queues again. Note that $ISRGn[TR3]$ acts as an enabler of this bit when in mul mode. That is group $g$ must be programmed to accept $Tx$ ring 3 interrupt before this bit can be set.           | ndition            |
| Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                              |                    |
| Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |
| <ul><li>Invalid BD or data address</li><li>Uncorrectable error on BD or data read</li></ul>                                                                                                                                                                                                                                                                                                                                        |                    |

Table continues on the next page...

## P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eTSECx\_TSTATn field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4<br>THLT4 | Transmit halt of ring 4 . Set by the eTSEC if is no longer processing transmit frames from this TxBD ring, and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be cleared by writing 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN4], or if no ready TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.    |
|            | Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error condition recurs and halts all queues again. Note that ISRGn[TR4] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept Tx ring 4 interrupt before this bit can be set. |
|            | Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                                |
|            | Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | <ul><li>Invalid BD or data address</li><li>Uncorrectable error on BD or data read</li></ul>                                                                                                                                                                                                                                                                                                                                          |
|            | TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5<br>THLT5 | Transmit halt of ring 5 . Set by the eTSEC if is no longer processing transmit frames from this TxBD ring, and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be cleared by writing 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN5], or if no ready TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.    |
|            | Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error condition recurs and halts all queues again. Note that ISRGn[TR5] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept Tx ring 5 interrupt before this bit can be set. |
|            | Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                                |
|            | Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | <ul> <li>Invalid BD or data address</li> <li>Uncorrectable error on BD or data read</li> </ul>                                                                                                                                                                                                                                                                                                                                       |
|            | TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6<br>THLT6 | Transmit halt of ring 6. Set by the eTSEC if is no longer processing transmit frames from this TxBD ring, and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be cleared by writing 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN6], or if no ready TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.     |
|            | Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error condition recurs and halts all queues again. Note that ISRGn[TR6] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept Tx ring 6 interrupt before this bit can be set. |
|            | Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                                |
|            | Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | <ul> <li>Invalid BD or data address</li> <li>Uncorrectable error on BD or data read</li> </ul>                                                                                                                                                                                                                                                                                                                                       |
|            | TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                           |

## eTSECx\_TSTATn field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>THLT7 | Transmit halt of ring 7. Set by the eTSEC if is no longer processing transmit frames from this TxBD ring, and DMA from this ring is disabled. To restart transmission from this TxBD ring, this bit must be cleared by writing 1 to it. This bit is set only on a general error condition, regardless of TQUEUE[EN7], or if no ready TxBDs can be fetched. DMACTRL[GTS] being set by the user does not cause this bit to be set.    |
|            | Software should examine the halted queue's buffer descriptors for repeatable error conditions before taking it out of the halt state. Failure to do so may cause an effective livelock, in which the error condition recurs and halts all queues again. Note that ISRGn[TR7] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 7 interrupt before this bit can be set. |
|            | Repeatable error conditions which cause halt include:                                                                                                                                                                                                                                                                                                                                                                               |
|            | Bus error:                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            | <ul> <li>Invalid BD or data address</li> <li>Uncorrectable error on BD or data read</li> </ul>                                                                                                                                                                                                                                                                                                                                      |
|            | TxBD programming errors:                                                                                                                                                                                                                                                                                                                                                                                                            |
|            | • Ready = 1 and length = 0                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8–15<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16<br>TXF0 | Transmit frame event occurred on ring 0 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR0] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 0 interrupt before this bit can be set.                                                                                                             |
| 17<br>TXF1 | Transmit frame event occurred on ring 1 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR1] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 1 interrupt before this bit can be set.                                                                                                             |
| 18<br>TXF2 | Transmit frame event occurred on ring 2 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR2] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 2 interrupt before this bit can be set.                                                                                                             |
| 19<br>TXF3 | Transmit frame event occurred on ring 3 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR3] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 3 interrupt before this bit can be set.                                                                                                             |
| 20<br>TXF4 | Transmit frame event occurred on ring 4 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR4] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 4 interrupt before this bit can be set.                                                                                                             |
| 21<br>TXF5 | Transmit frame event occurred on ring 5 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR5] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 5 interrupt before this bit can be set.                                                                                                             |
| 22<br>TXF6 | Transmit frame event occurred on ring 6 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR6] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 6 interrupt before this bit can be set.                                                                                                             |
| 23<br>TXF7 | Transmit frame event occurred on ring 7 . Set by the eTSEC if IEVENTG $g$ [TxF] was set in relation to transmitting a frame from this ring. Note that ISRGn[TR7] acts as an enabler of this bit when in multigroup mode. That is group $g$ must be programmed to accept Tx ring 7 interrupt before this bit can be set.                                                                                                             |
| 24–31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |

## 15.5.14 Default VLAN control word \* (eTSECx\_DFVLAN)

This register defines the default value for the VLAN Ethertype and control word when VLAN tags are automatically inserted by the eTSEC, and no per-frame VLAN data is supplied by software . On receive, this register defines a customizable VLAN Ethertype for automatic deletion . Note that an Ethertype of 0x8808 (Control Word) is not permitted as a custom VLAN tag. Frames with an Ethertype of 0x8808 are dropped by the receiver . In the case of frames containing stacked VLAN tags, this register defines the tag associated with the outer or metropolitan area VLAN.



| Bit    | 0   | 1   | 2  | 3   | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
|--------|-----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| R<br>W | TAG |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset  | 1   | 0   | 0  | 0   | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 16  | 17  | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| R<br>W |     | PRI |    | CFI |    |    |    |    |    | V  | ID |    |    |    |    |    |
| Reset  | 0   | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### eTSECx\_DFVLAN field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>TAG  | This is the default Ethertype used to tag VLAN frames. On transmit, this tag is inserted ahead of the VLAN control word; TAG should be set to 0x8100 for IEEE 802.1Q VLAN. On receive, an Ethertype matching TAG or an Ethertype of 0x8100 marks a VLAN-tagged frame.                          |
|              | Note that if using DFVLAN to set a custom ethertype (that is, using a value other than 0x8100), packets received with a custom tag are not counted by any of the RMON counters. Affected counters include TRMGV, RMCA, RBCA, RXCF, RXPF, RXUO, RALN, RFLR, ROVR, RJBR, TMCA, TBCA, TXPF, TXCF. |
| 16–18<br>PRI | This is the default value used for the IEEE Std. 802.1p frame priority.                                                                                                                                                                                                                        |
| 19<br>CFI    | This is the default value used for the IEEE Std. 802.1Q canonical format indicator.                                                                                                                                                                                                            |
| 20–31<br>VID | This is the default value used for the virtual-LAN identifier in VLAN-tagged frames. A value of zero is defined as the null VLAN, however field PRI may be still set independently.                                                                                                            |

## 15.5.15 Transmit interrupt coalescing register (eTSECx\_TXIC)

The TXIC register enables and configures the operational parameters for interrupt coalescing associated with transmitted frames . This register address is aliased with TXICO when in multigroup mode.



**Field** Description 0 Interrupt coalescing enable **ICEN** Interrupt coalescing is disabled. Interrupts are raised as they are received. Interrupt coalescing is enabled. If the eTSEC transmit frame interrupt is enabled, an interrupt is raised when the threshold number of frames is reached (defined by TXIC[ICFT]) or when the threshold timer expires (determined by TXIC[ICTT]). 1 Interrupt coalescing timer clock source. **ICCS** The coalescing timer advances count every 64 eTSEC Tx interface clocks (TSEC n \_GTX\_CLK). The coalescing timer advances count every 64 system clocks <sup>1</sup> . This mode is recommended for FIFO operation. 2 This field is reserved. Reserved

#### eTSECx\_TXIC field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3–10<br>ICFT  | Interrupt coalescing frame count threshold . While interrupt coalescing is enabled (TXIC[ICEN] is set), this value determines how many frames are transmitted before raising an interrupt . The eTSEC threshold counter is reset to ICFT following an interrupt . The value of ICFT must be greater than zero to avoid unpredictable behavior .                                                                                                                                                                                                                                                                                                                                                                   |
| 11–15<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 16–31<br>ICTT | Interrupt coalescing timer threshold . While interrupt coalescing is enabled (TXIC[ICEN] is set), this value determines the maximum amount of time after transmitting a frame before raising an interrupt . If frames have been transmitted but the frame count threshold has not been met, an interrupt is raised when the threshold timer reaches zero . The threshold timer is reset to the value in this field and begins counting down upon transmission of the first frame having its TxBD[I] bit set . The threshold value is represented in units of 64 clock periods as specified by the timer clock source (TXIC[ICCS]) . The value of ICTT must be greater than zero to avoid unpredictable behavior . |

<sup>1.</sup> The term 'system clock' refers to CCB clock/2.

## 15.5.16 Transmit queue control register \* (eTSECx\_TQUEUE)

The TQUEUE register selectively enables each of the TxBD rings 0-7 . By default, TxBD ring 0 is enabled.





#### eTSECx\_TQUEUE field descriptions

| Field     | Description                                                                                                                                                |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                           |
| 16<br>EN0 | Transmit queue 0 enable.  TxBD ring is not queried for transmission. In effect the transmit queue is disabled.  TxBD ring is queried for transmission.     |
| 17<br>EN1 | Transmit queue 1 enable.  O TxBD ring is not queried for transmission. In effect the transmit queue is disabled.  1 TxBD ring is queried for transmission. |
| 18<br>EN2 | Transmit queue 2 enable.                                                                                                                                   |

#### eTSECx\_TQUEUE field descriptions (continued)

| Field     | Description                                                                            |
|-----------|----------------------------------------------------------------------------------------|
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 19<br>EN3 | Transmit queue 3 enable.                                                               |
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 20<br>EN4 | Transmit queue 4 enable.                                                               |
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 21<br>EN5 | Transmit queue 5 enable.                                                               |
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 22<br>EN6 | Transmit queue 6 enable.                                                               |
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 23<br>EN7 | Transmit queue 7 enable.                                                               |
|           | 0 TxBD ring is not queried for transmission. In effect the transmit queue is disabled. |
|           | 1 TxBD ring is queried for transmission.                                               |
| 24–31     | This field is reserved.                                                                |
| -         | Reserved                                                                               |

# 15.5.17 TxBD Rings 0-3 round-robin weightings \* (eTSECx\_TR03WT)

When modified weighted round-robin Tx scheduling is enabled (TCTRL[TXSCHED] = 10), this register determines the weighting applied to each transmit queue for queues 0 to 3. For priority-based scheduling, TR03WT has no effect. A description of how queue weights affect eTSEC's round-robin algorithm appears in Modified weighted round-robin queuing (MWRR).

Address: Base address + 140h offset



#### eTSECx\_TR03WT field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>WT0   | Weighting value for TxBD ring 0 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT0 x 64 bytes of data are scheduled for transmission from TxBD ring 0. Clearing this field prevents transmission. This field should only be updated when it's corresponding queue is disabled by register TQUEUE, or the queue is halted (TSTAT $n$ [THLT $m$ = 1]). |
| 8–15<br>WT1  | Weighting value for TxBD ring 1 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT1 x 64 bytes of data are scheduled for transmission from TxBD ring 1. Clearing this field prevents transmission. This field should only be updated when it's corresponding queue is disabled by register TQUEUE, or the queue is halted (TSTAT $n$ [THLT $m$ = 1]). |
| 16–23<br>WT2 | Weighting value for TxBD ring 2 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT2 x 64 bytes of data are scheduled for transmission from TxBD ring 2. Clearing this field prevents transmission. This field should only be updated when it's corresponding queue is disabled by register TQUEUE, or the queue is halted (TSTAT $n$ [THLT $m$ = 1]). |
| 24–31<br>WT3 | Weighting value for TxBD ring 3 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT3 x 64 bytes of data are scheduled for transmission from TxBD ring 3. Clearing this field prevents transmission. This field should only be updated when it's corresponding queue is disabled by register TQUEUE, or the queue is halted (TSTAT $n$ [THLT $m$ = 1]). |

# 15.5.18 TxBD Rings 4-7 round-robin weightings \* (eTSECx\_TR47WT)

When modified weighted round-robin Tx scheduling is enabled (TCTRL[TXSCHED] = 10), this register determines the weighting applied to each enabled transmit queue for queues 4 to 7. For priority-based scheduling, TR47WT has no effect. A description of how queue weights affect eTSEC's modified weighted round-robin algorithm appears in Modified weighted round-robin queuing (MWRR).

Address: Base address + 144h offset



#### eTSECx\_TR47WT field descriptions

| Field        | Description                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>WT4   | Weighting value for TxBD ring 4 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT4 x 64 bytes of data are scheduled for transmission from TxBD ring 4. Clearing this field prevents transmission. |
| 8–15<br>WT5  | Weighting value for TxBD ring 5 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT5 x 64 bytes of data are scheduled for transmission from TxBD ring 5. Clearing this field prevents transmission. |
| 16–23<br>WT6 | Weighting value for TxBD ring 6 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT6 x 64 bytes of data are scheduled for transmission from TxBD ring 6. Clearing this field prevents transmission. |

#### eTSECx\_TR47WT field descriptions (continued)

| Field | Description                                                                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Weighting value for TxBD ring 7 when TCTRL[TXSCHED] = 10. On each round of the Tx scheduler, a minimum of WT7 x 64 bytes of data are scheduled for transmission from TxBD ring 7. Clearing this field prevents transmission. |

### 15.5.19 Tx data buffer pointer high bits \* (eTSECx\_TBDBPH)

The TBDBPH register is written by the user with the most significant address bits common to all TxBD buffer addresses, TxBD[Data Buffer Pointer]. As a consequence, all Tx buffers must be placed in a 4 gigabyte segment of memory whose base address is prefixed by the bits in TBDBPH. The TxBD ring itself can reside in a different memory region (based at TBASEH).

Address: Base address + 180h offset



#### eTSECx\_TBDBPH field descriptions

| Field     | Description                                                                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>- | This field is reserved. Reserved                                                                                                                            |
| 1         | Most significant bits common to all data buffer addresses contained in TxBDs . The user must initialize TBDBPH before enabling the eTSEC transmit function. |

## 15.5.20 TxBD pointer for ring n (eTSECx\_TBPTRn)

TBPTR0-TBPTR7 each contains the low-order 32 bits of the next transmit buffer descriptor address for their respective TxBD ring . These registers takes on the value of their ring's associated TBASE when the TBASE register is written by software . Software must not write TBPTR0-TBPTR7 while eTSEC is actively transmitting frames. However, TBPTR0- TBPTR7 can be modified when the transmitter is disabled or when no Tx buffer is in use (after a GRACEFUL STOP TRANSMIT command is issued and the frame completes its transmission) in order to change the next TxBD eTSEC transmits .





#### eTSECx\_TBPTRn field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–28<br>TBPTRn | Current TxBD pointer for TxBD ring $n$ . Points to the current BD being processed or to the next BD the transmitter uses when it is idling. When the end of the TxBD ring is reached, eTSEC initializes TBPTR $n$ to the value in the corresponding TBASE $n$ . The TBPTR register is internally written by the eTSEC's DMA controller during transmission. The pointer increments by eight (bytes) each time a descriptor is closed successfully by the eTSEC. Note that the three least significant bits of this register are read-only and zero. After an error condition, the eTSEC returns TBPTR $n$ to point to the first BD of the frame partially transmitted. |
| 29–31<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## 15.5.21 TxBD base address high bits \* (eTSECx\_TBASEH)

The TBASEH register is written by the user with the most significant address bits common to all TxBD addresses, including TBASE0-TBASE7 and TBPTR0-TBPTR7. As a consequence, all TxBD rings must be placed in a 4 Gbyte segment of memory whose base address is prefixed by the bits in TBASEH. Data buffers are located in a potentially different region, based at TBDBPH.

Address: Base address + 200h offset



#### eTSECx\_TBASEH field descriptions

| Field           | Description                                                                                                                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–27<br>-       | This field is reserved. Reserved                                                                                                                             |
| 28–31<br>TBASEH | Most significant bits common to all TxBD addresses-except data buffer pointers. The user must initialize TBASEH before enabling the eTSEC transmit function. |

## 15.5.22 TxBD base address of ring n (eTSECx\_TBASEn)

The TBASE *n* registers are written by the user with the base address of each TxBD ring *n*. Each such value must be divisible by eight, since the three least significant bits always write as 000.

Address: Base address + 204h offset + (8d × i), where i=0d to 7d



#### eTSECx\_TBASEn field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Transmit base for ring $n$ . TBASE defines the starting location in the memory map for the eTSEC TxBDs. This field must be 8-byte aligned. Together with setting the W (wrap) bit in the last BD, the user can select how many BDs to allocate for the transmit packets. The user must initialize TBASE before enabling the eTSEC transmit function on the associated ring. |
| 29–31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                            |

# 15.5.23 Tx time stamp identification tag [set n] \* (eTSECx\_TMR\_TXTSn\_ID)

Transmit time stamp identification register (TMR\_TXTS t\_ID). This register holds the identification number of the transmitted frame corresponding to the time stamp captured in TMR\_TXTS t\_H/L. Each time the eTSEC is instructed to capture the time stamp of an outgoing frame via TxFCB[PTP] the associated field in TxFCB[PTP\_ID] is stored in this register, overwriting the previous value.

This register is read only in normal operation.

#### eTSEC memory map/register definition





#### eTSECx\_TMR\_TXTSn\_ID field descriptions

| Field            | Description                        |
|------------------|------------------------------------|
| 0–15<br>-        | This field is reserved. Reserved   |
| 16–31<br>TXTS_ID | Tx time stamp identification field |

## 15.5.24 Tx time stamp high [set n] \* (eTSECx\_TMR\_TXTSn\_H)

The transmit stamp high register (TMR\_TXTS n \_H) holds the value of the TMR\_CNT\_H when a frame tagged for time stamp capture (via Tx FCB[PTP]) is transmitted. Upon transmission of the start of frame symbol of such a frame, the value in TMR\_CNT\_H is copied into TMR\_TXTS n \_H.

These registers are read only in normal operation.





#### eTSECx\_TMR\_TXTSn\_H field descriptions

| Field          | Description                                                                             |
|----------------|-----------------------------------------------------------------------------------------|
| 0–31<br>TXTS_H | Time stamp field of the transmitted PTP packet's start of frame detection (upper half). |

## 15.5.25 Tx time stamp low [set n] \* (eTSECx\_TMR\_TXTSn\_L)

The transmit stamp low register (TMR\_TXTS n \_L) holds the value of the TMR\_CNT\_L when a frame tagged for time stamp capture (via Tx FCB[PTP]) is transmitted. Upon transmission of the start of frame symbol of such a frame, the value in TMR\_CNT\_L is copied into TMR\_TXTS n \_L.

These registers are read only in normal operation.





#### eTSECx\_TMR\_TXTSn\_L field descriptions

| Field          | Description                                                                            |
|----------------|----------------------------------------------------------------------------------------|
| 0–31<br>TXTS_L | Time stamp field of the transmitted PTP packet's start of frame detection (lower half) |

## 15.5.26 Receive control register (eTSECx\_RCTRL)

The RCTRL register is programmed by the user and controls the operational mode of the receiver. It must be written only after a system reset (at initialization) or after a graceful receive stop has completed.

10

13

15





## eTSECx\_RCTRL field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–6<br>L2OFF | Layer 2 offset. The number of octet pairs from the start of the frame that the parser should expect to see before the first byte of the Ethernet DA.                                                                                                                                                                                                                                                                                                                                                                                                                |
|              | For frames received over Ethernet, the start of frame is regarded as the SFD symbol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|              | For packets received through the FIFO packet interface the start of frame is regarded as the first octet of receive data. Note that this device does not support FIFO interface mode.                                                                                                                                                                                                                                                                                                                                                                               |
|              | The user may think of this value as representing the length - in multiples of two bytes - of a 'shim' header that is inserted between the SFD and DA. By writing to RCTRL with a mask of 0xFE00_0000, the even byte length restriction is guaranteed.                                                                                                                                                                                                                                                                                                               |
|              | For normal frames, this field should be left as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7<br>TS      | Time stamp incoming packets as padding bytes. PAL field is set to 8 if the PAL field is programmed to less than 8. Must be set to zero if TMR_CTRL[TE]=0.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8–9<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10<br>RR     | This bit is the select of mux between round robin counter and lower 3-bit of hash results. Output of this mux is used in ring index mapping logic.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | 0 Lower 3-bit hash result is selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|              | 1 Round robin counter is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11–15<br>PAL | Packet alignment padding length . If not zero, PAL (1-31) bytes of zero padding are inserted before the start of each received frame, but following the RxFCB if TOE is enabled . For Ethernet where optional preamble extraction is enabled, the padding appears before the preamble, otherwise the padding precedes the layer 2 header . The value of PAL can be set so that the start of the IP header in the receive data buffer is aligned to a 32-bit boundary. Normally, setting PAL = 2 provides minimal padding to ensure such alignment of the IP header. |
|              | Note that the minimum zero padding value for this field should be PAL-8 if the TS field is set and 0 when PAL is < 8.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16<br>CFA    | Control frame accept. Overrides 802.3 standard control frame behavior. When set, all ethernet frames that have an ethertype of 0x8808 are treated as normal ethernet frames and passed up to the stack on a DA match. This bit has no effect on frames received over the FIFO packet interface.                                                                                                                                                                                                                                                                     |
|              | 0 Control frames are sunk in the MAC layer and not passed up the stack .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|              | 1 Ignore 802.3 specified behavior and DMA received frames to memory on a DA match.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17<br>LFC    | Lossless flow control. When set, the eTSEC determines the number of free BDs (through RQPARMn[LEN] and RBTPTRn) in each active ring. Should the free BD count in an active ring drop below its setting for RQPARMn[FBTHR], the eTSEC asserts link layer flow control.                                                                                                                                                                                                                                                                                               |
|              | For full-duplex ethernet connections, the eTSEC emits a pause frame as if TCTRL[TFC_PAUSE] was set. For FIFO packet interface connections, the RFC signal is asserted.                                                                                                                                                                                                                                                                                                                                                                                              |
|              | 0 Disabled . This is the default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|              | 1 Enabled, calculate the free BDs in each active ring and assert link layer flow control if required.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18<br>VLEX   | Enable automatic VLAN tag extraction and deletion from Ethernet frames . Note that VLEX must be cleared if L2OFF is non-zero.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|              | Note that if PRSDEP is cleared, VLEX must be cleared as well. (VLAN tag extraction is only supported when the parser is enabled.)                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | 0 Do not delete VLAN tags from received Ethernet frames .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | 1 If a VLAN tag is seen after the Ethernet source address, and PRSDEP is non-zero, delete the VLAN tag and return the VLAN control word in the frame control block returned with this frame.                                                                                                                                                                                                                                                                                                                                                                        |

## eTSECx\_RCTRL field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19<br>FILREN    | Filer enable . When set, the receive frame filer is enabled. This file accepted frames to a particular RxBD ring according to rules defined in the filer table. In this case, PRSDEP must not be cleared .                                                                                                                                                                                               |
|                 | Note that if PRSDEP is cleared, FILREN must be cleared as well.                                                                                                                                                                                                                                                                                                                                          |
|                 | O Do not search the receive queue filer table for received frames. All received frames are sent to RxBD ring 0 by default.                                                                                                                                                                                                                                                                               |
|                 | 1 Search the receive queue filer table for received frames, and let the filer determine the index of the RxBD ring for each frame.                                                                                                                                                                                                                                                                       |
| 20<br>FSQEN     | Enable single-queue mode for the receive frame filer. This bit is ignored unless FILREN is also set.                                                                                                                                                                                                                                                                                                     |
| 104211          | <ul> <li>The filer chooses the RxBD ring using the least significant bits of the virtual queue ID as a ring index.</li> <li>The filer always attempts to file received frames to ring 0, regardless of virtual queue ID. This mode is intended for operating the filer as a packet classification engine.</li> </ul>                                                                                     |
| 21<br>GHTX      | Group address hash table extend . By default, the group address hash table is 256 entries (as defined by registers GADDR0-GADDR7); registers IGADDR0-IGADDR7 are then used to define the individual address hash table . When this bit is set, the hash table is extended to a total of 512 entries (IGADDR0-IGADDR7 are then the first 256 entries of the extended 512-entry group address hash table). |
|                 | Both the individual and group hash functions are the 8 MSBs of the CRC-32 of the Ethernet destination address.                                                                                                                                                                                                                                                                                           |
|                 | 1 The group hash function is the 9 MSBs of the CRC-32 of the Ethernet destination address. The individual address hash function is unavailable.                                                                                                                                                                                                                                                          |
| 22<br>IPCSEN    | IP Checksum verification enable . See Receive path offload .                                                                                                                                                                                                                                                                                                                                             |
| iii GGEIT       | <ul> <li>IPv4 header checksums are not verified by the eTSEC-even if layer 3 parsing is enabled.</li> <li>Perform IPv4 header checksum verification if PRSDEP &gt; 01.</li> </ul>                                                                                                                                                                                                                        |
| 23<br>TUCSEN    | TCP or UDP Checksum verification enable . See Receive path offload .                                                                                                                                                                                                                                                                                                                                     |
| TOCSEN          | <ul> <li>TCP or UDP checksums are not verified by the eTSEC-even if layer 4 parsing is enabled.</li> <li>Perform TCP or UDP checksum verification if PRSDEP = 11.</li> </ul>                                                                                                                                                                                                                             |
| 24–25<br>PRSDEP | If this field is non-zero, a TOE frame control block is prepended to the received frame, and the first RxBD points to the FCB.                                                                                                                                                                                                                                                                           |
|                 | Note that if PRSDEP is cleared, VLEX must be cleared as well. (VLAN tag extraction is only supported when the parser is enabled.) Also, if PRSDEP is cleared, FILREN must also be cleared.                                                                                                                                                                                                               |
|                 | Parser control . The level of parser layer recognition is determined as follows:                                                                                                                                                                                                                                                                                                                         |
|                 | 00 Parser disabled. Receive frame filer must also be disabled by clearing RCTRL[FILREN] .                                                                                                                                                                                                                                                                                                                |
|                 | Only L2 (Ethernet) protocols are recognized.                                                                                                                                                                                                                                                                                                                                                             |
|                 | <ul> <li>L2 and L3 (IP) protocols are recognized over any interface not configured as a FIFO interface.</li> <li>L2, L3, and L4 (TCP/UDP) protocols are recognized over any interface not configured as a FIFO interface.</li> </ul>                                                                                                                                                                     |
| 26<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                         |
| 27<br>BC_REJ    | Broadcast frame reject . If this bit is set, frames with DA (destination address) = FFFF_FFFF are rejected unless RCTRL[PROM] is set . If both BC_REJ and RCTRL[PROM] are set, then frames with broadcast DA are accepted and the M (MISS) bit is set in the receive BD.                                                                                                                                 |
| 28<br>PROM      | Promiscuous mode . All Ethernet frames, regardless of destination address, are accepted.                                                                                                                                                                                                                                                                                                                 |

#### eTSECx\_RCTRL field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                        |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29      | Receive short frame mode . When set, enables the reception of frames shorter than 64 bytes.                                                                                                                                                        |
| RSF     | Note that frames less than or equal to 16B in length are always silently dropped .                                                                                                                                                                 |
|         | 0 Ethernet frames less than 64B in length are silently dropped.                                                                                                                                                                                    |
|         | 1 Frames more than 16B and less than 64B in length are accepted upon a DA match.                                                                                                                                                                   |
| 30      | Exact match MAC address enable . If this bit is set, the MAC01ADDR1-MAC15ADDR1 and                                                                                                                                                                 |
| EMEN    | MAC01ADDR2-MAC15ADDR2 registers are recognized as containing MAC addresses aliasing the MAC's station address. Setting this bit therefore allows eTSEC to receive Ethernet frames having a destination address matching one of these 15 addresses. |
| 31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                   |

## 15.5.27 Receive status register (eTSECx\_RSTATn)

The eTSEC writes to this register under the following conditions:

- A frame interrupt event occurred on one or more RxBD rings that are assigned to group *g*
- The receiver runs out of descriptors due to a busy condition on a RxBD ring that is assigned to groupg
- The receiver was halted because an error condition was encountered while receiving a frame that is assigned to group *g*

Writing 1 to any bit of this register clears it. Software should clear the QHLT *m* bit to take eTSEC's receiver function out of halt state for the associated queue.



0

0

0

0

0

0

0

0

Reset

0

0

0

0

0

0



### eTSECx\_RSTATn field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0–7         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
| 8<br>QHLT0  | RxBD queue 0 is halted . It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT0 to be set.) . The current frame and all other frames directed to a halted queue are discarded . A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR0] acts as an enabler of this bit when in multi-group mode. That is group <i>g</i> must be programmed to accept rx ring 0 interrupt before this bit can be set. |  |  |  |  |  |  |  |  |  |
|             | <ul> <li>This queue is enabled for reception. (That is, it is not halted)</li> <li>All controller receive activity to this queue is halted.</li> </ul>                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| 9<br>QHLT1  | RxBD queue 1 is halted . It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT1 to be set.) . The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR1] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 1 interrupt before this bit can be set.       |  |  |  |  |  |  |  |  |  |
|             | <ul> <li>This queue is enabled for reception. (That is, it is not halted)</li> <li>All controller receive activity to this queue is halted.</li> </ul>                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| 10<br>QHLT2 | RxBD queue 2 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT2 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR2] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 2 interrupt before this bit can be set.         |  |  |  |  |  |  |  |  |  |
|             | <ul> <li>This queue is enabled for reception. (That is, it is not halted)</li> <li>All controller receive activity to this queue is halted.</li> </ul>                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| 11<br>QHLT3 | RxBD queue 3 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT3 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR3] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 3 interrupt before this bit can be set.         |  |  |  |  |  |  |  |  |  |
|             | <ul> <li>This queue is enabled for reception. (That is, it is not halted)</li> <li>All controller receive activity to this queue is halted.</li> </ul>                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| 12<br>QHLT4 | RxBD queue 4 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT4 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR4] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 4 interrupt before this bit can be set.         |  |  |  |  |  |  |  |  |  |

# eTSECx\_RSTATn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|             | 0 This queue is enabled for reception. (That is, it is not halted)                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|             | 1 All controller receive activity to this queue is halted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| 13<br>QHLT5 | RxBD queue 5 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT5 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR5] acts as an enabler of this bit when in multi-group mode. That is group <i>g</i> must be programmed to accept rx ring 5 interrupt before this bit can be set.  O This queue is enabled for reception. (That is, it is not halted) |  |  |  |  |  |  |  |  |
|             | 1 All controller receive activity to this queue is halted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| 14<br>QHLT6 | RxBD queue 6 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT6 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR6] acts as an enabler of this bit when in multi-group mode. That is group <i>g</i> must be programmed to accept rx ring 6 interrupt before this bit can be set.  O This queue is enabled for reception. (That is, it is not halted) |  |  |  |  |  |  |  |  |
|             | 1 All controller receive activity to this queue is halted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| 15<br>QHLT7 | RxBD queue 7 is halted. It is a hardware-initiated stop indication. (DMACTRL[GRS] being set by the user does not cause a QHLT7 to be set.). The current frame and all other frames directed to a halted queue are discarded. A write with a value of 1 re-enables the queue for receiving. Note that ISRGn[RR7] acts as an enabler of this bit when in multi-group mode. That is group <i>g</i> must be programmed to accept rx ring 7 interrupt before this bit can be set.                                                                     |  |  |  |  |  |  |  |  |
|             | <ul><li>This queue is enabled for reception. (That is, it is not halted)</li><li>All controller receive activity to this queue is halted.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| 16–23<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 24<br>RXF0  | Receive frame event occurred on ring 0 . Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring . Note that ISRGn[RR0] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 0 interrupt before this bit can be set                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| 25<br>RXF1  | Receive frame event occurred on ring 1. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR1] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 1 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 26<br>RXF2  | Receive frame event occurred on ring 2. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR2] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 2 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 27<br>RXF3  | Receive frame event occurred on ring 3. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR3] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 3 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 28<br>RXF4  | Receive frame event occurred on ring 4. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR4] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 4 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 29<br>RXF5  | Receive frame event occurred on ring 5. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR5] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 5 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 30<br>RXF6  | Receive frame event occurred on ring 6. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR6] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 6 interrupt before this bit can be set                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |

### eTSECx\_RSTATn field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RXF7 | Receive frame event occurred on ring 7. Set by the eTSEC if IEVENTG $g$ [RXF] was set in relation to receiving a frame to this ring. Note that ISRGn[RR7] acts as an enabler of this bit when in multi-group mode. That is group $g$ must be programmed to accept rx ring 7 interrupt before this bit can be set |

# 15.5.28 Receive interrupt coalescing register (eTSECx\_RXIC)

The RXIC register enables and configures the operational parameters for interrupt coalescing associated with received frames . Note that this register address is aliased with RXIC0 when in multi-group mode.



| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ICEN | <ul> <li>Interrupt coalescing enable</li> <li>Interrupt coalescing is disabled. Interrupts are raised as they are received.</li> <li>Interrupt coalescing is enabled. If the eTSEC receive frame interrupt is enabled, an interrupt is raised when the threshold number of frames is reached (defined by RXIC[ICFT]) or when the threshold timer expires (determined by RXIC[ICTT]).</li> </ul> |

### eTSECx\_RXIC field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>ICCS     | Interrupt coalescing timer clock source .  The coalescing timer advances count every 64 eTSEC Rx interface clocks (TSECn_GTX_CLK).  The coalescing timer advances count every 64 system clocks <sup>1</sup> . This mode is recommended for FIFO operation.                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2 -           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3–10<br>ICFT  | Interrupt coalescing frame count threshold. While interrupt coalescing is enabled (RXIC[ICE] is set), this value determines how many frames are received before raising an interrupt. The eTSEC threshold counter is reset to ICFT following an interrupt. The value of ICFT must be greater than zero avoid unpredictable behavior.                                                                                                                                                                                                                                                                                                                                     |
| 11–15<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16–31<br>ICTT | Interrupt coalescing timer threshold . While interrupt coalescing is enabled (RXIC[ICE] is set), this value determines the maximum amount of time after receiving a frame before raising an interrupt . If frames have been received but the frame count threshold has not been met, an interrupt is raised when the threshold timer reaches zero . The threshold timer is reset to the value in this field and begins counting down upon receiving the first frame having its RxBD[I] bit set . The threshold value is represented in units equal to 64 periods of the clock specified by RXIC[ICCS] . ICTT must be greater than zero to avoid unpredictable behavior . |

<sup>1.</sup> The term 'system clock' refers to CCB clock/2.

# 15.5.29 Receive queue control register \* (eTSECx\_RQUEUE)

The RQUEUE register enables each of the RxBD rings 0-7 . By default, RxBD ring 0 is enabled.

Address: Base address + 314h offset



#### eTSECx\_RQUEUE field descriptions

| Field    | Description                      |  |  |  |  |  |  |  |
|----------|----------------------------------|--|--|--|--|--|--|--|
| 0–7      | This field is reserved. Reserved |  |  |  |  |  |  |  |
| 8<br>EX0 | Receive queue 0 extract enable . |  |  |  |  |  |  |  |

# eTSECx\_RQUEUE field descriptions (continued)

| Field     | Description                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|           | Data transferred by DMA to this RxBD ring is not extracted to cache.                                                                                                                         |  |  |  |  |  |  |  |  |
|           | 1 Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.                                                                                                 |  |  |  |  |  |  |  |  |
| 9<br>EX1  | Receive queue 1 extract enable .                                                                                                                                                             |  |  |  |  |  |  |  |  |
|           | Data transferred by DMA to this RxBD ring is not extracted to cache.      Data transferred by DMA to this RxBD ring undergoes outrection according to ATTD register.                         |  |  |  |  |  |  |  |  |
| 10        | Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.      Describe average 0 outrook analytic.                                                         |  |  |  |  |  |  |  |  |
| 10<br>EX2 | Receive queue 2 extract enable .                                                                                                                                                             |  |  |  |  |  |  |  |  |
|           | <ul> <li>Data transferred by DMA to this RxBD ring is not extracted to cache.</li> <li>Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.</li> </ul> |  |  |  |  |  |  |  |  |
| 11<br>EX3 | Receive queue 3 extract enable .                                                                                                                                                             |  |  |  |  |  |  |  |  |
| LAS       | Data transferred by DMA to this RxBD ring is not extracted to cache.                                                                                                                         |  |  |  |  |  |  |  |  |
|           | 1 Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.                                                                                                 |  |  |  |  |  |  |  |  |
| 12<br>EX4 | Receive queue 4 extract enable .                                                                                                                                                             |  |  |  |  |  |  |  |  |
|           | O Data transferred by DMA to this RxBD ring is not extracted to cache.                                                                                                                       |  |  |  |  |  |  |  |  |
|           | 1 Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.                                                                                                 |  |  |  |  |  |  |  |  |
| 13<br>EX5 | Receive queue 5 extract enable.                                                                                                                                                              |  |  |  |  |  |  |  |  |
|           | <ul> <li>Data transferred by DMA to this RxBD ring is not extracted to cache.</li> <li>Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.</li> </ul> |  |  |  |  |  |  |  |  |
| 14        | Receive queue 6 extract enable.                                                                                                                                                              |  |  |  |  |  |  |  |  |
| EX6       |                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|           | O Data transferred by DMA to this RxBD ring is not extracted to cache.                                                                                                                       |  |  |  |  |  |  |  |  |
|           | 1 Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.                                                                                                 |  |  |  |  |  |  |  |  |
| 15<br>EX7 | Receive queue 7 extract enable .                                                                                                                                                             |  |  |  |  |  |  |  |  |
|           | 0 Data transferred by DMA to this RxBD ring is not extracted to cache.                                                                                                                       |  |  |  |  |  |  |  |  |
|           | 1 Data transferred by DMA to this RxBD ring undergoes extraction according to ATTR register.                                                                                                 |  |  |  |  |  |  |  |  |
| 16–23     | This field is reserved. Reserved                                                                                                                                                             |  |  |  |  |  |  |  |  |
| 24<br>EN0 | Receive queue 0 enable.                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| LINO      | 0 RxBD ring is not queried for reception . In effect the receive queue is disabled.                                                                                                          |  |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                                                                                                                                        |  |  |  |  |  |  |  |  |
| 25<br>EN1 | Receive queue 1 enable .                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled.                                                                                                           |  |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                                                                                                                                        |  |  |  |  |  |  |  |  |
| 26<br>EN2 | Receive queue 2 enable .                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled.                                                                                                           |  |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                                                                                                                                        |  |  |  |  |  |  |  |  |
| 27<br>EN3 | Receive queue 3 enable .                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled.                                                                                                           |  |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                                                                                                                                        |  |  |  |  |  |  |  |  |

### eTSECx\_RQUEUE field descriptions (continued)

| Field     | Description                                                                        |  |  |  |  |  |  |  |
|-----------|------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 28<br>EN4 | Receive queue 4 enable .                                                           |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled. |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                              |  |  |  |  |  |  |  |
| 29<br>EN5 | Receive queue 5 enable .                                                           |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled. |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                              |  |  |  |  |  |  |  |
| 30<br>EN6 | Receive queue 6 enable .                                                           |  |  |  |  |  |  |  |
|           | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled. |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                              |  |  |  |  |  |  |  |
| 31        | Receive queue 7 enable .                                                           |  |  |  |  |  |  |  |
| EN7       | 0 RxBD ring is not queried for reception. In effect the receive queue is disabled. |  |  |  |  |  |  |  |
|           | 1 RxBD ring is queried for reception.                                              |  |  |  |  |  |  |  |

# 15.5.30 Ring mapping register n \* (eTSECx\_RIRn)

The RIR *n* registers provides a mapping from the nominal round-robin or filer hash value to ring index. See Ring index mapping logic for details.

Address: Base address + 318h offset +  $(4d \times i)$ , where i=0d to 3d



### eTSECx\_RIRn field descriptions

| Field        | Description                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------|
| 0–2<br>RD0   | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 000 |
| 3–5<br>RD1   | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 001 |
| 6–8<br>RD2   | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 010 |
| 9–11<br>RD3  | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 011 |
| 12–14<br>RD4 | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 100 |
| 15–17<br>RD5 | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 101 |

### eTSECx\_RIRn field descriptions (continued)

| Field        | Description                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------|
| 18–20<br>RD6 | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 110 |
| 21–23<br>RD7 | The 3-bit ring index to use for filing when round robin or lower 3 bits of filer hash result is 111 |
| 24–31<br>-   | This field is reserved. Reserved                                                                    |

# 15.5.31 Receive bit field extract control register \* (eTSECx\_RBIFX)

The RBIFX register provides a set of four 6-bit offsets for locating up to four octets in a received frame and passing them to the receive queue filer as the user-defined ARB property . Through RBIFX a custom ARB filer property can be constructed from arbitrary bytes, which allows frame filing on the basis of bitfields not ordinarily provided to the filer, such as bits from the Ethernet preamble or TCP flags . The value of property ARB is the concatenation of {B0, B1, B2, B3} to 32-bits, where B0-B3 are the bytes as defined by RBIFX .

Address: Base address + 330h offset

| Bit    | 0      | 1  | 2        | 3  | 4    | 5    | 6  | 7   | 8             | 9   | 10 | 11   | 12   | 13   | 14 | 15 |
|--------|--------|----|----------|----|------|------|----|-----|---------------|-----|----|------|------|------|----|----|
| R<br>W | I BOCH |    | B0OFFSET |    |      |      |    | B10 | B1CTL B1OFFSE |     |    | FSET |      |      |    |    |
| Reset  | 0      | 0  | 0        | 0  | 0    | 0    | 0  | 0   | 0             | 0   | 0  | 0    | 0    | 0    | 0  | 0  |
| Bit    | 16     | 17 | 18       | 19 | 20   | 21   | 22 | 23  | 24            | 25  | 26 | 27   | 28   | 29   | 30 | 31 |
| R<br>W | B2CTL  |    |          |    | B2OF | FSET |    |     | B30           | CTL |    |      | B3OF | FSET |    |    |
| Reset  | 0      | 0  | 0        | 0  | 0    | 0    | 0  | 0   | 0             | 0   | 0  | 0    | 0    | 0    | 0  | 0  |

### eTSECx\_RBIFX field descriptions

| Field        | Description                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0-1<br>B0CTL | Location of byte 0 of property ARB.                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|              | 00 Byte 0 is not extracted, and appears as zero in property ARB.                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|              | O1 Byte 0 is located in the received frame at offset (B0OFFSET - 8) bytes from the first byte of the Ethernet DA. In non-FIFO modes, a negative effective offset points to bytes of the standard Ethernet preamble . Values of B0OFFSET less than 8 are reserved in FIFO modes. |  |  |  |  |  |  |  |  |  |
|              | 10 Byte 0 is located in the received frame at offset B0OFFSET bytes from the byte after the last byte of the layer 2 header.                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|              | Byte 0 is located in the received frame at offset B0OFFSET bytes from the byte after the last byte of the layer 3 header.                                                                                                                                                       |  |  |  |  |  |  |  |  |  |

## eTSEC memory map/register definition

# eTSECx\_RBIFX field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                    |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2–7<br>B0OFFSET   | Offset relative to the header defined by B0CTL that locates byte 0 of property ARB . An effective offset of zero points to the first byte of the specified header.                                                                                                             |  |  |  |
| 8–9<br>B1CTL      | Location of byte 1 of property ARB.                                                                                                                                                                                                                                            |  |  |  |
|                   | 00 Byte 1 is not extracted, and appears as zero in property ARB.                                                                                                                                                                                                               |  |  |  |
|                   | O1 Byte 1 is located in the received frame at offset (B10FFSET - 8) bytes from the first byte of the Ethernet DA. In non-FIFO modes, a negative effective offset points to bytes of the standard Ethernet preamble. Values of B10FFSET less than 8 are reserved in FIFO modes. |  |  |  |
|                   | Byte 0 is located in the received frame at offset B10FFSET bytes from the byte after the last byte of the layer 2 header.                                                                                                                                                      |  |  |  |
|                   | Byte 0 is located in the received frame at offset B1OFFSET bytes from the byte after the last byte of the layer 3 header .                                                                                                                                                     |  |  |  |
| 10–15<br>B1OFFSET | Offset relative to the header defined by B1CTL that locates byte 1 of property ARB. An effective offset of zero points to the first byte of the specified header.                                                                                                              |  |  |  |
| 16–17<br>B2CTL    | Location of byte 2 of property ARB.                                                                                                                                                                                                                                            |  |  |  |
|                   | 00 Byte 2 is not extracted, and appears as zero in property ARB.                                                                                                                                                                                                               |  |  |  |
|                   | O1 Byte 2 is located in the received frame at offset (B2OFFSET - 8) bytes from the first byte of the Ethernet DA. In non-FIFO modes, a negative effective offset points to bytes of the standard Ethernet preamble. Values of B2OFFSET less than 8 are reserved in FIFO modes. |  |  |  |
|                   | Byte 0 is located in the received frame at offset B2OFFSET bytes from the byte after the last byte of the layer 2 header.                                                                                                                                                      |  |  |  |
|                   | Byte 0 is located in the received frame at offset B2OFFSET bytes from the byte after the last byte of the layer 3 header .                                                                                                                                                     |  |  |  |
| 18–23<br>B2OFFSET | Offset relative to the header defined by B2CTL that locates byte 2 of property ARB. An effective offset of zero points to the first byte of the specified header.                                                                                                              |  |  |  |
| 24–25<br>B3CTL    | Location of byte 3 of property ARB.                                                                                                                                                                                                                                            |  |  |  |
|                   | 00 Byte 3 is not extracted, and appears as zero in property ARB.                                                                                                                                                                                                               |  |  |  |
|                   | O1 Byte 3 is located in the received frame at offset (B3OFFSET - 8) bytes from the first byte of the Ethernet DA. In non-FIFO modes, a negative effective offset points to bytes of the standard Ethernet preamble. Values of B3OFFSET less than 8 are reserved in FIFO modes. |  |  |  |
|                   | Byte 0 is located in the received frame at offset B3OFFSET bytes from the byte after the last byte of the layer 2 header.                                                                                                                                                      |  |  |  |
|                   | Byte 0 is located in the received frame at offset B3OFFSET bytes from the byte after the last byte of the layer 3 header .                                                                                                                                                     |  |  |  |
| 26–31<br>B3OFFSET | Offset relative to the header defined by B3CTL that locates byte 3 of property ARB. An effective offset of zero points to the first byte of the specified header.                                                                                                              |  |  |  |

# 15.5.32 Receive queue filing table address register \* (eTSECx\_RQFAR)

RQFAR contains the index of the current, indirectly accessible entry of the received queue filer table. Each table entry occupies a pair of 32-bit words, denoted RQCTRL and RQPROP. To access the RQCTRL and RQPROP words of entry n, write n to RQFAR. Then read or write the indexed RQCTRL and RQPROP words by reading or writing the RQFCR and RQFPR registers, respectively.





### eTSECx\_RQFAR field descriptions

| Field          | Description                                                                     |
|----------------|---------------------------------------------------------------------------------|
| 0–23           | This field is reserved. Reserved                                                |
| 24–31<br>RQFAR | Current index of receive queue filer table, which spans a total of 256 entries. |

# 15.5.33 Receive queue filer table control register \* (eTSECx\_RQFCR)

RQFCR is accessed to read or write the RQCTRL words in entries of the receive queue filer table. The table entries are described in greater detail in Receive queue filer. The word accessed through RQFCR is defined by the current value of RQFAR. Since RQFCR is read from internal SRAMs, SRAMs have to be initialized through register writes before RQFCR is read.



### eTSECx\_RQFCR field descriptions

| Field             | Description                                                                                                                                                                                                                                                        |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0<br>GPI          | General purpose interrupt  When a property matches the value in the RQPROP entry at this index, and REJ = 0 and AND = 0, the filer will instruct the Rx descriptor controller to set IEVENTG $g$ [FGPI] when the corresponding receive frame is written to memory. |  |  |  |
|                   | If the timer is enabled (TMR_CTRL[TE] = 1), then TMR_PEVENT[RXP] will also be set.                                                                                                                                                                                 |  |  |  |
| 1–11              | This field is reserved. Reserved, should be written with zero.                                                                                                                                                                                                     |  |  |  |
| 12-14<br>HASH_TBL | Select between filer Q value and RIR fileds. Only relevant on terminating rule. Note when RCTRL[RR] is set this bit field can be non-zero even if there is no rule has HASH set.                                                                                   |  |  |  |

# eTSECx\_RQFCR field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|              | 000 Use Q value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|              | 001 Distribute based on RIR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 010 Distribute based on RIR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 011 Distribute based on RIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 100 Distribute based on RIR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 101 Reserved 111 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 45           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 15<br>HASH   | HASH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|              | 0 Do not include parser results in hash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|              | 1 Include parser results in hash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 16–21<br>Q   | Receive queue index, from 0 to 63, inclusive, written into the Rx frame control block associated with the received frame. When a property matches the value in the RQPROP entry at this index, and REJ = 0 and AND = 0, the frame is sent to either RxBD ring 0 (if RCTRL[FSQEN] = 1) or the RxBD ring with index (Q mod 8) and the filing table search is terminated. In the case where RCTRL[FSQEN] = 0, 8 virtual receive queues are overlaid on every RxBD ring, and software needs to consult the RQ field of the Rx frame control block to determine which virtual receive queue was chosen. |  |  |  |  |
| 22           | Cluster entry/exit (used in combination with AND bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| CLE          | This bit brackets clusters, marking the start and end entries of a cluster. Clusters cannot be nested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|              | 0 Regular RQCTRL entry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|              | 1 If entry matches and AND = 1, treat subsequent entries as belonging to a nested cluster and enter the cluster; otherwise skip all entries up to and including the next cluster exit. If AND = 0, exit current cluster.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| 23           | Reject frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| REJ          | This bit and its specified action are ignored if AND = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|              | 0 If entry matches, accept frame and file it to RxBD ring Q.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 1 If entry matches, reject frame and discard it, ignoring Q.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 24<br>AND    | AND, in combination with CLE, REJ, and PID match, determines whether the filer will accept or reject a frame, defer evaluation until the next rule, exit a cluster, or skip a rule or set of rules.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|              | If CLE is zero:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|              | Match property[PID] against RQPROP. If matched, accept or reject frame based on REJ. Otherwise ski to next rule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|              | 1 Match property[PID] against RQPROP. If matched, defer evaluation to next rule. Otherwise, skip all rule up to and including the next rule with AND = 0. If the next rule with AND = 0 has CLE = 1, then also exit cluster.                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | If CLE is one:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|              | 0 Match property[PID] against RQPROP. If matched, accept or reject frame based on REJ. Otherwise, exit cluster.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|              | 1 Match property[PID] against RQPROP. If matched, enter cluster. Otherwise, skip all rules up to and including the next rule while CLE = 1 and AND = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| 25–26<br>CMP | Comparison operation to perform on the RQPROP entry at this index when PID > 0. The property value extracted by the frame parser is masked by the 32-bit <i>mask_register</i> prior to comparison against RQPROP. However, the property value is not permanently altered by the value in <i>mask_register</i> . By                                                                                                                                                                                                                                                                                 |  |  |  |  |
|              | default, mask_register is initialized to 0xFFFF_FFFF before each frame is processed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |

### eTSECx\_RQFCR field descriptions (continued)

| Field   | Description                                                                                                                                      |  |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         | 00/01 Filer mask_register is set to all 32 bits of RQPROP, and this entry always matches.                                                        |  |  |  |  |
|         | 10/11 Filer mask_register is set to all 32 bits of RQPROP, and this entry always fails to match.                                                 |  |  |  |  |
|         | In the case where PID > 0, CMP is interpreted as follows (& is bit-wise AND operator):                                                           |  |  |  |  |
|         | 00 property [PID] & mask_register = RQPROP                                                                                                       |  |  |  |  |
|         | 01 property [PID] & mask_register ≤ RQPROP                                                                                                       |  |  |  |  |
|         | 10 property [PID] & mask_register != RQPROP                                                                                                      |  |  |  |  |
|         | 11 property [PID] & mask_register < RQPROP                                                                                                       |  |  |  |  |
| 27<br>- | This field is reserved. Reserved, should be written with zero.                                                                                   |  |  |  |  |
| 28–31   | Property identifier                                                                                                                              |  |  |  |  |
| PID     | The value in the RQPROP entry at this index is interpreted according to PID (see Receive queue filing table property register * (eTSEC_RQFPR) ). |  |  |  |  |

# 15.5.34 Receive queue filing table property register \* (eTSECx\_RQFPR)

#### NOTE

This section describes the layout of RQFPR with property ID 1 only; for a description of its use with property IDs 0 and 2–15, see the table below.

RQFPR is accessed to read or write the RQPROP words in entries of the receive queue filer table. The table entries are described in greater detail in Receive queue filer and the table below. The word accessed through RQFPR is defined by the current value of RQFAR. Since RQFCR is read from internal SRAMs, SRAMs have to be initialized through register writes before RQFCR is read.

Table 15-310. RQFPR Field Descriptions (supplementary)

| PID <sup>1</sup> | Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000             | 0-31  | MASK | Mask bits to be written to Filer <code>mask_register</code> for masking of property values. The rule match/fail status for this PID is determined by RQCTRL[CMP]. Since <code>mask_register</code> is bit-wise ANDed with properties, every bit of MASK that is cleared also results in the corresponding property bit being cleared in comparisons. Therefore setting MASK to <code>0xFFFF_FFFF</code> ensures that all property bits participate in rule matches. |
| 0010             | 0-7   | ARB  | User-defined arbitrary bit field property: byte 0 extracted. Defaults to 0x00.                                                                                                                                                                                                                                                                                                                                                                                      |
| 0010             | 8-15  | ARB  | User-defined arbitrary bit field property: byte 1 extracted. Defaults to 0x00.                                                                                                                                                                                                                                                                                                                                                                                      |
| 0010             | 16-23 | ARB  | User-defined arbitrary bit field property: byte 2 extracted. Defaults to 0x00.                                                                                                                                                                                                                                                                                                                                                                                      |
| 0010             | 24-31 | ARB  | User-defined arbitrary bit field property: byte 3 extracted. Defaults to 0x00.                                                                                                                                                                                                                                                                                                                                                                                      |
| 0011             | 0-7   | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0011             | 8-31  | DAH  | Destination MAC address, most significant 24 bits. Defaults to 0x000000.                                                                                                                                                                                                                                                                                                                                                                                            |

# Table 15-310. RQFPR Field Descriptions (supplementary) (continued)

| PID <sup>1</sup> | Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0100             | 0-7   | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0100             | 8-31  | DAL  | Destination MAC address, least significant 24 bits. Defaults to 0x000000.                                                                                                                                                                                                                                                                                                                                                                                           |
| 0101             | 0-7   | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0101             | 8-31  | SAH  | Source MAC address, most significant 24 bits. Defaults to 0x000000.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0110             | 0-7   | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0110             | 8-31  | SAL  | Source MAC address, least significant 24 bits. Defaults to 0x000000.                                                                                                                                                                                                                                                                                                                                                                                                |
| 0111             | 0-15  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0111             | 16-31 | ETY  | Ethertype of next layer protocol, that is, last ethertype if layer 2 headers nest. Defaults to 0xFFFF.                                                                                                                                                                                                                                                                                                                                                              |
|                  |       |      | Using the filer to match ETY does not work in the case of PPPoE packets, because the PPPoE ethertype in the original packet, 0x8864, is always overwritten with the PPP protocol field. Thus, matches on ETY == 0x8864 always fail.                                                                                                                                                                                                                                 |
|                  |       |      | Instead, software should use PID=1 fields IP4 (ETY = 0x0021) and IP6 (ETY = 0x0057) to distinguish PPPoE session packets carrying IPv4 and IPv6 datagrams. Other PPP protocols are encoded in the ETY field, but many of them overlap with real ethertype definitions. Consult IANA and IEEE for possible ambiguities.                                                                                                                                              |
|                  |       |      | Packets with a value in the length/type field greater than 1500 and less than 1536 are treated as payload length. If the eTSEC is used in a network where there are packets carrying a type designation between 1500 and 1536 (note there are none currently publicly defined by IANA), then the software must confirm the parser and filer results by checking the type/length field after the packet has been written to memory to see if it falls in this range. |
|                  |       |      | Note that the eTSEC filer gets multiple packet attributes as a result of parsing the packet. The behavior of the eTSEC is that it pulls the innermost ethertype found in the packet; this means that in many supported protocols, it is impossible to create a filer rule that matches on the outer ethertype. There are four cases that need to be highlighted.                                                                                                    |
|                  |       |      | 1. The jumbo ethertype (0x8870)-In this case, the eTSEC assumes that the following header is LLC/SNAP. LLC/SNAP has an associated Ethertype, and the ETY field is populated with that ethertype. This makes it impossible to file on jumbo frames. In this case, one can use arbitrary extracted bytes to pull the outermost Ethertype.                                                                                                                             |
|                  |       |      | 2. The PPPoE ethertype described above.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                  |       |      | 3. The VLAN tag ethertype (0x8100)-In this case, one can use the PID1 VLN bit to indicate that the packet had a VLAN tag.                                                                                                                                                                                                                                                                                                                                           |
|                  |       |      | 4. The MPLS tagged packets . In this case, one can use arbitrary extraction bytes to compare to the actual ethertype if a filer rule is intending to file based on an MPLS label existence.                                                                                                                                                                                                                                                                         |
| 1000             | 0-19  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1000             | 20-31 | VID  | VLAN network identifier (as per IEEE Std 802.1Q). This value defaults to 0x000 if no VLAN tag was found, or the VLAN tag contained only priority information. Note that this field is valid only if the first encountered Ethertype in a frame is VLAN.                                                                                                                                                                                                             |
| 1001             | 0-28  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1001             | 29-31 | PRI  | VLAN user priority (as per IEEE Std 802.1p). This value defaults to 000 (best effort priority) if no VLAN tag was found. Note that this field is valid only if the first encountered Ethertype in a frame is VLAN.                                                                                                                                                                                                                                                  |
| 1010             | 0-23  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |

### Table 15-310. RQFPR Field Descriptions (supplementary) (continued)

| PID <sup>1</sup> | Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1010             | 24-31 | TOS  | IPv4 header Type Of Service field or IPv6 Traffic Class field. This value defaults to 0x00 (default RFC 2474 best-effort behavior) if no IP header appeared. In case of tunnelling, TOS is extracted from outermost layer.                                                                                                                                                                                      |
|                  |       |      | Note that for IPv6 the Traffic Class field is extracted using the IP header definition in RFC 2460. IPv6 headers formed using the earlier RFC 1883 have a different format and must be handled with software. (Software should acknowledge the PIC=1 IP6 bit to distinguish proper alignment of the TOS field.)                                                                                                 |
| 1011             | 0-23  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                          |
| 1011             | 24-31 | L4P  | Layer 4 protocol identifier as per published IANA specification                                                                                                                                                                                                                                                                                                                                                 |
|                  |       |      | This is the last recognized protocol type recognized in the case of IPv6 extension headers. This value defaults to 0xFF to indicate that no layer 3 header was recognized (possibly due to absence of an IP header). In case of tunnelling, L4P is extracted from innermost layer.                                                                                                                              |
| 1100             | 0-31  | DIA  | Destination IP address                                                                                                                                                                                                                                                                                                                                                                                          |
|                  |       |      | If an IPv4 header was found, this is the entire destination address. If an IPv6 header was found, this is the 32 most significant bits of the 128-bit destination address. This value defaults to all zeros if no IP header appeared. Note that in case of tunnelling, DIA is extracted from outermost IP header; in case of IPv6 routing header, DIA is extracted from last routing header of outermost layer. |
| 1101             | 0-31  | SIA  | Source IP address                                                                                                                                                                                                                                                                                                                                                                                               |
|                  |       |      | If an IPv4 header was found, this is the entire source address. If an IPv6 header was found, this is the 32 most significant bits of the 128-bit source address. This value defaults to all zeros if no IP header appeared. Note that in case of tunnelling or IPv6 routing header, SIA is extracted from outermost IP header.                                                                                  |
| 1110             | 0-15  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                          |
| 1110             | 16-31 | DPT  | Destination port number for TCP or UDP headers                                                                                                                                                                                                                                                                                                                                                                  |
|                  |       |      | This value defaults to 0x0000 if no TCP or UDP headers were recognized.                                                                                                                                                                                                                                                                                                                                         |
| 1111             | 0-15  | -    | Reserved, should be written with zero.                                                                                                                                                                                                                                                                                                                                                                          |
| 1111             | 16-31 | SPT  | Source port number for TCP or UDP headers                                                                                                                                                                                                                                                                                                                                                                       |
|                  |       |      | This value defaults to 0x0000 if no TCP or UDP headers were recognized.                                                                                                                                                                                                                                                                                                                                         |

- 1. PID is the property identifier field of the filer table control entry (see RQFCR[PID]) at the same index.
- 1. PID is the property identifier field of the filer table control entry (see RQFCR[PID]) at the same index.
- 1. PID is the property identifier field of the filer table control entry (see RQFCR[PID]) at the same index.
- 1. PID is the property identifier field of the filer table control entry (see RQFCR[PID]) at the same index.

Address: Base address + 33Ch offset





### eTSECx\_RQFPR field descriptions

| Field     | Description                                                                                                                                                                                          |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–13<br>- | This field is reserved. Reserved                                                                                                                                                                     |  |  |
|           | (PID 0001)                                                                                                                                                                                           |  |  |
| 14        | Set if an ARP response packet is seen.                                                                                                                                                               |  |  |
| AR        | (PID 0001)                                                                                                                                                                                           |  |  |
| 15        | Set if an ARP request packet is seen.                                                                                                                                                                |  |  |
| ARQ       | (PID 0001)                                                                                                                                                                                           |  |  |
| 16        | Set if the destination Ethernet address is to the broadcast address.                                                                                                                                 |  |  |
| EBC       | (PID 0001)                                                                                                                                                                                           |  |  |
| 17        | Set if a VLAN tag (Ethertype DFVLAN[TAG] or 0x8100) was seen in the frame.                                                                                                                           |  |  |
| VLN       | (PID 0001)                                                                                                                                                                                           |  |  |
| 18<br>CFI | Set to the value of the Canonical Format Indicator in the VLAN control tag if VLAN is set, zero otherwise. Note that this field is valid only if the first encountered Ethertype in a frame is VLAN. |  |  |
|           | (PID 0001)                                                                                                                                                                                           |  |  |
| 19        | Set if a jumbo Ethernet frame was parsed.                                                                                                                                                            |  |  |
| JUM       | (PID 0001)                                                                                                                                                                                           |  |  |
| 20        | Set if a fragmented IPv4 or IPv6 header was encountered.                                                                                                                                             |  |  |
| IPF       | See the descriptions of receive FCB fields IP and PRO in Receive path offload, for more information on determining the status of received packets for which IPF is set.                              |  |  |
|           | (PID 0001)                                                                                                                                                                                           |  |  |
| 21        | This field is reserved.                                                                                                                                                                              |  |  |
| -         | Reserved                                                                                                                                                                                             |  |  |
|           | (PID 0001)                                                                                                                                                                                           |  |  |
| 22<br>IP4 | Set if an IPv4 header was parsed.                                                                                                                                                                    |  |  |
|           | (PID 0001)                                                                                                                                                                                           |  |  |
| 23<br>IP6 | Set if an IPv6 header was parsed.                                                                                                                                                                    |  |  |
| 11 0      | (PID 0001)                                                                                                                                                                                           |  |  |
| 24<br>ICC | Set if the IPv4 header checksum was checked.                                                                                                                                                         |  |  |
| 100       | (PID 0001)                                                                                                                                                                                           |  |  |

#### eTSEC memory map/register definition

### eTSECx\_RQFPR field descriptions (continued)

| Field     | Description                                             |  |  |
|-----------|---------------------------------------------------------|--|--|
| 25        | Set if the IPv4 header checksum was verified correct.   |  |  |
| ICV       | (PID 0001)                                              |  |  |
| 26        | Set if a TCP header was parsed.                         |  |  |
| TCP       | (PID 0001)                                              |  |  |
| 27        | Set if a UDP header was parsed.                         |  |  |
| UDP       | (PID 0001)                                              |  |  |
| 28–29     | This field is reserved.                                 |  |  |
| -         | Reserved.                                               |  |  |
|           | (PID 0001)                                              |  |  |
| 30<br>PER | Set on a parse error, such as header inconsistency.     |  |  |
| PER       | (PID 0001)                                              |  |  |
| 31        | Set on an Ethernet framing error that prevents parsing. |  |  |
| EER       | (PID 0001)                                              |  |  |

<sup>1.</sup> PID is the property identifier field of the filer table control entry (see RQFCR[PID]) at the same index.

# 15.5.35 Maximum receive buffer length register (eTSECx\_MRBLR)

The MRBLR register is written by the user. It informs the eTSEC how much space is in the receive buffer pointed to by the RxBD.

Address: Base address + 340h offset



#### eTSECx\_MRBLR field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 16–25<br>MRBL | MRBL is the number of bytes that the eTSEC receiver writes to the receive buffer . The MRBL register is written by the user with a multiple of 64 for all modes . The eTSEC can write fewer bytes to the buffer than the value set in MRBL if a condition such as an error or end-of-frame occurs, but it never exceeds the MRBL value; therefore, user-supplied buffers must be at least as large as the MRBL. MRBL must be set, together with the number of buffer descriptors, to ensure adequate space for received frames. See Maximum frame length (eTSEC_MAXFRM) , for further discussion. |  |  |
| 26–31<br>-    | This field is reserved. To ensure that MRBL is a multiple of 64, these bits are reserved and should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

# 15.5.36 Receive packet wakeup timer register (eTSECx\_RPWT)

The RPWT register is written by the user. It is the amount of time to wait before waking up the system after a packet has been received and eTSEC is in sleep mode.

Address: Base address + 350h offset



#### eTSECx\_RPWT field descriptions

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0<br>EN  | Enable.                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|          | 0 Disable wakeup timer feature                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|          | 1 Enable wakeup timer feature                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 1<br>LPD | LFC Pause Disable.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|          | 0 Disable LFC sending pause frame                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|          | 1 Enable LFC sending pause frame                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 2–3<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 4–19     | Timer value                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| TIMER    | Indicates the amount of time to wait before waking up the system. The timer starts after a packet is accepted and written to memory and the eTSEC has already been put into sleep mode previously. 0 value is reserved. Each increment value represents 2^22 eTSEC clocks. When the timer expires, an interrupt will be raised. See Group Interrupt event register (eTSEC_IEVENTGn), for more information. |  |  |
| 20–31    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                           |  |  |

## 15.5.37 Rx data buffer pointer high bits \* (eTSECx\_RBDBPH)

The RBDBPH register is written by the user with the most significant address bits common to all RxBD buffer addresses, RxBD[Data Buffer Pointer]. As a consequence, Rx buffers must be placed in a 4 Gbyte segment of memory whose base address is prefixed by the bits in RBDBPH. The RxBD ring itself can reside in a different memory region (based at RBASEH).





#### eTSECx\_RBDBPH field descriptions

| Field     | Description                                                                                                                                                |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–27<br>- | This field is reserved. Reserved                                                                                                                           |  |
|           | Most significant bits common to all data buffer addresses contained in RxBDs . The user must initialize RBDBPH before enabling the eTSEC receive function. |  |

# 15.5.38 RxBD pointer for ring n (eTSECx\_RBPTRn)

RBPTR0-RBPTR7 each contains the low-order 32 bits of the next receive buffer descriptor address for their respective RxBD ring . These registers takes on the value of their ring's associated RBASE when the RBASE register is written by software . Software must not write RBPTR *n* while eTSEC is actively receiving frames . However, RBPTR *n* can be modified when the receiver is disabled or when no Rx buffer is in use (after a GRACEFUL STOP RECEIVE command is issued and the frame completes its reception) in order to change the next RxBD eTSEC receives.

Address: Base address + 384h offset + (8d  $\times$  i), where i=0d to 7d



#### eTSECx\_RBPTRn field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                        |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–28       | Current RxBD pointer for RxBD ring n                                                                                                                                                                                                                                                                                                               |  |
| RBPTRn     | Points to the current BD being processed or to the next BD the receiver uses when it is idling. After reset or when the end of the RxBD ring is reached,                                                                                                                                                                                           |  |
|            | eTSEC initializes RBPTR $n$ to the value in the corresponding RBASE $n$ . The RBPTR register is internally written by the eTSEC's DMA controller during reception. The pointer increments by 8 (bytes) each time a descriptor is closed successfully by the eTSEC. Note that the 3 least-significant bits of this register are read only and zero. |  |
| 29–31<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                   |  |

# 15.5.39 RxBD base address high bits \* (eTSECx\_RBASEH)

The RBASEH register is written by the user with the most significant address bits common to all RxBD addresses, including RBASE0-RBASE7 and RBPTR0-RBPTR7. As a consequence, RxBD rings must be placed in a 4 Gbyte segment of memory whose base address is prefixed by the bits in RBASEH. However, Rx data buffers may potentially reside in a different memory region based at RBDBPH.

Address: Base address + 400h offset



#### eTSECx\_RBASEH field descriptions

| Field | Description                                                                                                                                                 |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| _     | This field is reserved. Reserved                                                                                                                            |  |
|       | Most significant bits common to all RxBD addresses-except data buffer pointers. The user must initialize RBASEH before enabling the eTSEC receive function. |  |

## 15.5.40 RxBD base address of ring n (eTSECx\_RBASEn)

The RBASE n registers are written by the user with the base address of each RxBD ring n. Each such value must be divisible by eight, since the 3 least-significant bits always write as 000.





#### eTSECx\_RBASEn field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–28<br>RBASEn | Receive base for ring <i>n</i> RBASE defines the starting location in the memory map for the eTSEC RxBDs. This field must be 8-byte aligned. Together with setting the W (wrap) bit in the last BD, the user can select how many BDs to allocate for the receive packets. The user must initialize RBASE before enabling the eTSEC receive function on the associated ring. |
| 29–31<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                            |

# 15.5.41 Rx timer time stamp register high \* (eTSECx\_TMR\_RXTS\_H)

Together with TMR\_CNT\_L, this register holds the value present in TMR\_CNT\_H/L when the eTSEC detects a new incoming Ethernet frame. This register is only updated when the precision time stamp logic is enable via TMR\_CTRL[TE]. This register is read only in normal operation.

#### Address: Base address + 4C0h offset



#### eTSECx\_TMR\_RXTS\_H field descriptions

| Field      | Description                                                                                         |
|------------|-----------------------------------------------------------------------------------------------------|
| 0–31       | Value of the eTSEC precision timer upon detection of a start of frame symbol for the received frame |
| TMR_RXTS_H | (upper half).                                                                                       |

# 15.5.42 Rx timer time stamp register low \* (eTSECx\_TMR\_RXTS\_L)

Together with TMR\_RXTS\_H, this register holds the value present in TMR\_CNT\_H/L when the eTSEC detects a new incoming Ethernet frame. These registers are only updated when the precision time stamp logic is enable via TMR\_CTRL[TE]. This register is read only in normal operation.





#### eTSECx\_TMR\_RXTS\_L field descriptions

| Field      | Description                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------|
|            | Value of the eTSEC precision timer upon detection of a start of frame symbol for the received frame (lower |
| TMR_RXTS_L | half).                                                                                                     |

# 15.5.43 MAC configuration register 1 (eTSECx\_MACCFG1)

MACCFG1 is written by the user. Note that the reset bits in MACCFG1 are not self-resetting. If software sets any reset bit in MACCFG1, it must leave the bit asserted at least three Tx clocks, then clear the bit before resuming normal operation. See MAC functionality for more details.



# eTSECx\_MACCFG1 field descriptions

| Field              | Description                                                                                                                                                                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Soft_Reset    | Soft reset . This bit is cleared by default . See Soft reset and reconfiguring procedure , for more information on setting this bit.                                                                         |
|                    | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Place the entire MAC in reset except for the host interface .                                                                                                                                              |
| 1–11               | This field is reserved. Reserved                                                                                                                                                                             |
| 12<br>Reset_Rx_MC  | Reset receive MAC control block . This bit is cleared by default.                                                                                                                                            |
|                    | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Place the receive part of the MAC in reset . This block detects control frames and contains the pause timers.                                                                                              |
| 13<br>Reset_Tx_MC  | Reset transmit MAC control block . This bit is cleared by default.                                                                                                                                           |
|                    | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Place the transmit part of the MAC in reset . This block multiplexes data and control frame transfers . It also responds to XOFF PAUSE control frames.                                                     |
| 14<br>Reset_Rx_Fun | Reset receive function block . This bit is cleared by default.                                                                                                                                               |
|                    | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Place the receive function in reset . This block performs the receive frame protocol.                                                                                                                      |
| 15<br>Reset_Tx_Fun | Reset transmit function block . This bit is cleared by default.                                                                                                                                              |
| neset_1x_ruii      | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Place the transmit function in reset . This block performs the frame transmission protocol.                                                                                                                |
| 16–22<br>-         | This field is reserved. Reserved                                                                                                                                                                             |
| 23                 | Loop back . This bit is cleared by default.                                                                                                                                                                  |
| Loop_Back          | NOTE: MAC_level loopback is not supported in 10-bit modes.                                                                                                                                                   |
|                    | 0 Normal operation.                                                                                                                                                                                          |
|                    | 1 Loop back the MAC transmit outputs to the MAC receive inputs.                                                                                                                                              |
| 24–25<br>-         | This field is reserved. Reserved                                                                                                                                                                             |
| 26<br>Rx_Flow      | Receive flow . This bit is cleared by default.                                                                                                                                                               |
|                    | 0 The receive MAC control ignores PAUSE flow control frames.                                                                                                                                                 |
|                    | 1 The receive MAC control detects and acts on PAUSE flow control frames .                                                                                                                                    |
| 27<br>Tx_Flow      | Transmit flow . This bit is cleared by default.                                                                                                                                                              |
|                    | 0 The transmit MAC control may not send PAUSE flow control frames if requested by the system.                                                                                                                |
|                    | The transmit MAC control may send PAUSE flow control frames if requested by the system.                                                                                                                      |
| 28<br>Syncd_Rx_EN  | Receive enable synchronized to the receive stream . (Read-only)                                                                                                                                              |
|                    | 0 Frame reception is not enabled.                                                                                                                                                                            |
|                    | 1 Frame reception is enabled.                                                                                                                                                                                |
| 29<br>Rx_EN        | Receive enable . This bit is cleared by default. If set, prior to clearing this bit, set DMACTRL[GRS] then confirm subsequent occurrence of the graceful receive stop interrupt (IEVENTG $g$ [GRSC] is set). |

#### eTSEC memory map/register definition

## eTSECx\_MACCFG1 field descriptions (continued)

| Field             | Description                                                                                                                                                                                                   |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                   | 0 The MAC may not receive frames from the PHY.                                                                                                                                                                |  |
|                   | 1 The MAC may receive frames from the PHY.                                                                                                                                                                    |  |
| 30<br>Syncd_Tx_EN | Transmit enable synchronized to the transmit stream . (Read-only)                                                                                                                                             |  |
| -,                | 0 Frame transmission is not enabled.                                                                                                                                                                          |  |
|                   | 1 Frame transmission is enabled.                                                                                                                                                                              |  |
| 31<br>Tx_EN       | Transmit enable . This bit is cleared by default. If set, prior to clearing this bit, set DMACTRL[GTS] then confirm subsequent occurrence of the graceful receive stop interrupt (IEVENTG $g$ [GTSC] is set). |  |
|                   | 0 The MAC may not transmit frames from the system.                                                                                                                                                            |  |
|                   | 1 The MAC may transmit frames from the system.                                                                                                                                                                |  |

# 15.5.44 MAC configuration register 2 (eTSECx\_MACCFG2)

The MACCFG2 register is written by the user. See MAC functionality for more details.

| Frame type          | Frame length            | Packet truncation | BD[TR] set to 1 |
|---------------------|-------------------------|-------------------|-----------------|
| Receive or transmit | > maximum frame length  | yes               | yes             |
| Receive             | == maximum frame length | no                | no              |
| Transmit            | = =maximum frame length | no                | yes             |
| Receive or transmit | < maximum frame length  | no                | no              |



# eTSECx\_MACCFG2 field descriptions

| Field                    | Description                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–15<br>-                | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 16–19<br>Preamble_Length | This field determines the length in bytes of the preamble field preceding each Ethernet start-of-frame delimiter byte. Values from 0x3 to 0xF are supported by the controller. The default value of 0x7 should not be altered in order to guarantee reliable operation with IEEE 802.3 compliant hardware.                                                                                     |  |  |
| 20–21                    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 22–23<br>I_F_Mode        | This field determines the type of interface to which the MAC is connected. Its default is 00. See Ethernet control register (eTSEC_ECNTRL) for detailed settings.                                                                                                                                                                                                                              |  |  |
|                          | 00 Reserved 01 Nibble mode; used for the following mode(s):MII (10/100 Mbps),RMII (10/100 Mbps), 10 Byte mode 11 Reserved                                                                                                                                                                                                                                                                      |  |  |
| 24<br>PreAMRxEN          | User defined preamble enable for received frames . This bit is cleared by default.                                                                                                                                                                                                                                                                                                             |  |  |
|                          | <ul> <li>The MAC skips the Ethernet preamble without returning it.</li> <li>The MAC recovers the received Ethernet preamble and passes it to the driver at the start of each received frame. If the preamble is less than 7 bytes, 0's are prepended to pad it to 7 bytes. Not applicable toor RMII 10/100modes .</li> </ul>                                                                   |  |  |
| 25<br>PreAMTxEN          | User defined preamble enable for transmitted frames . This bit is cleared by default.                                                                                                                                                                                                                                                                                                          |  |  |
| 110,1111,12              | <ul> <li>The MAC generates a standard Ethernet preamble.</li> <li>If a user-defined preamble has been passed to the MAC it is transmitted instead of the standard preamble. Otherwise the standard Ethernet preamble is generated. The Preamble Length field should be left at its default setting if a user-defined preamble is transmitted. Not applicable toor RMII 10/100modes.</li> </ul> |  |  |
| 26                       | Huge Frame enable . This bit is cleared by default.                                                                                                                                                                                                                                                                                                                                            |  |  |
| Huge_Frame               | Note that if Huge_Frame is cleared, the user must ensure that adequate buffer space is allocated for received frames. See Maximum frame length (eTSEC_MAXFRM), for further information.                                                                                                                                                                                                        |  |  |
|                          | Limit the length of frames received to less than or equal to the maximum frame length value (MAXFRM[Maximum Frame]) and limit the length of frames transmitted to less than the maximum frame length. See Buffer descriptors, for further details of buffer descriptor bit updating.                                                                                                           |  |  |
|                          | 1 Frames are transmitted and received regardless of their relationship to the maximum frame length.                                                                                                                                                                                                                                                                                            |  |  |
| 27<br>Length_check       | <ul> <li>Length check . This bit is cleared by default.</li> <li>No length field checking is performed.</li> <li>The MAC checks the frame's length field on receive to ensure it matches the actual data field length. Transmitted frames are not checked.</li> </ul>                                                                                                                          |  |  |
| 28<br>MPEN               | Magic packet enable for Ethernet modes. This bit is cleared by default. MPEN should be enabled only after GRACEFUL RECEIVE STOP and GRACEFUL TRANSMIT STOP are completed successfully (in other words, transmission and reception have stopped).                                                                                                                                               |  |  |
|                          | <ul> <li>Normal receive behavior on receive, or Magic Packet mode has exited with reception of a valid Magic Packet.</li> <li>Commence Magic Packet detection by the MAC provided that frame reception is enabled in</li> </ul>                                                                                                                                                                |  |  |
|                          | MACCFG1. In this mode the MAC ignores all received frames until the specific Magic Packet frame is received, at which point this bit is cleared by the eTSEC, and a maskable interrupt through IEVENTG $g$ [MAG] occurs.                                                                                                                                                                       |  |  |

## eTSECx\_MACCFG2 field descriptions (continued)

| Field        | Description                                                                                                                                           |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 29           | Pad and append CRC . This bit is cleared by default.                                                                                                  |  |
| PAD_CRC      | This bit must be set when in half-duplex mode (MACCFG2[Full_Duplex] is cleared).                                                                      |  |
|              | 0 Frames presented to the MAC have a valid length and contain a CRC.                                                                                  |  |
|              | 1 The MAC pads all transmitted short frames and appends a CRC to every frame regardless of padding requirement.                                       |  |
| 30<br>CRC_EN | CRC enable . If the configuration bit PAD_CRC ENABLE or the per-packet PAD_CRC ENABLE is set, CRC ENABLE is ignored . This bit is cleared by default. |  |
|              | 0 Frames presented to the MAC have a valid length and contain a valid CRC.                                                                            |  |
|              | 1 The MAC appends a CRC on all frames . Clear this bit if frames presented to the MAC have a valid length and contain a valid CRC.                    |  |
| 31           | Full duplex configure . This bit is cleared by default.                                                                                               |  |
| Full_Duplex  | 0 The MAC operates in half-duplex mode only.                                                                                                          |  |
|              | 1 The MAC operates in full-duplex mode.                                                                                                               |  |

# 15.5.45 Interpacket/interframe gap register (eTSECx\_IPGIFG)

The IPGIFG register is written by the user . See MAC functionality for more details.



# eTSECx\_IPGIFG field descriptions

| Field                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0 -                                  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 1–7<br>IPGR1                         | Non_Back_to_Back_Interpacket_Gap_Part_1  This is a programmable field representing the optional carrier sense window referenced in IEEE 802.3/4.2.3.2.1 'carrier deference'. If carrier is detected during the timing of IPGR1, the MAC defers to carrier. If, however, carrier becomes active after IPGR1, the MAC continues timing IPGR2 and transmits, knowingly causing a collision, thus ensuring fair access to medium. Its range of values is 0x00 to IPGR2. Its default is 0x40 (64d) which follows the two-thirds/one-third guideline.  NOTE: To correctly follow the two-thirds/one-third guideline, program IPGR1 to 0x5C, assuming that IPGR2 is the default 0x60 (96d). If the IPGR2 value is anything other than default use the following equation to calculate IPGR1= [(2/3 X IPGR2) + 28]. |  |
| 8 -                                  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 9–15<br>IPGR2                        | Non_Back_to_Back_Interpacket_Gap_Part_2  This is a programmable field representing the non-back-to-back interpacket-gap in bits . Its default is 0x60 (96d), which represents the minimum IPG of 96 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 16–23<br>Minimum_IFG_<br>Enforcement | This is a programmable field representing the minimum number of bits of IFG to enforce between frames . A frame is dropped whose IFG is less than that programmed . The default setting of 0x50 (80d) represents half of the nominal minimum IFG which is 160 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 24<br>-                              | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 25–31<br>IPGR3                       | Back_to_Back_Interpacket_Gap  This is a programmable field representing the IPG between back-to-back packets. This is the IPG parameter used exclusively in full-duplex mode and in half-duplex mode if two transmit packets are sent back-to-back. Set this field to the number of bits of IPG desired. The default setting of 0x60 (96d) represents the minimum IPG of 96 bits.                                                                                                                                                                                                                                                                                                                                                                                                                           |  |

# 15.5.46 Half-duplex control (eTSECx\_HAFDUP)

The HAFDUP register is written by the user. See MAC functionality for more details.



### eTSECx\_HAFDUP field descriptions

| Field                          | Description                                                                                                                                                                                                                                 |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7                            | This field is reserved. Reserved                                                                                                                                                                                                            |
| 8–11 Alternate_BEB_ Truncation | This field is used while ALTERNATE BINARY EXPONENTIAL BACKOFF ENABLE is set . The value programmed is substituted for the Ethernet standard value of ten . Its default is 0xA.                                                              |
| 12<br>Alt_BEB                  | Alternate binary exponential backoff . This bit is cleared by default.                                                                                                                                                                      |
|                                | The Tx MAC follows the standard binary exponential back off rule.                                                                                                                                                                           |
|                                | 1 The Tx MAC uses the ALTERNATE BINARY EXPONENTIAL BACKOFF TRUNCATION setting instead of the 802.3 standard tenth collision . The standard specifies that any collision after the tenth uses one less than 210 as the maximum backoff time. |
| 13<br>BP_No_BackOff            | Back pressure no backoff . This bit is cleared by default.                                                                                                                                                                                  |
| Di _ito_baokon                 | 0 The Tx MAC follows the binary exponential back off rule.                                                                                                                                                                                  |
|                                | 1 The Tx MAC immediately re-transmits, following a collision, during back pressure operation.                                                                                                                                               |
| 14<br>No_BackOff               | No backoff . This bit is cleared by default.                                                                                                                                                                                                |
| _                              | 0 The Tx MAC follows the binary exponential back off rule.                                                                                                                                                                                  |
|                                | 1 The Tx MAC immediately re-transmits following a collision.                                                                                                                                                                                |
| 15<br>Excess_Defer             | Excessively deferred . This bit is set by default.                                                                                                                                                                                          |
|                                | 0 The Tx MAC aborts the transmission of a packet that is excessively deferred.                                                                                                                                                              |
|                                | 1 The Tx MAC allows the transmission of a packet that is excessively deferred.                                                                                                                                                              |

### eTSECx\_HAFDUP field descriptions (continued)

| Field                               | Description                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16–19<br>Retransmission_<br>Maximum | This is a programmable field specifying the number of retransmission attempts following a collision before aborting the packet due to excessive collisions . The standard specifies the attempt limit to be 0xF (15d) . Its default value is 0xF.                                                                                               |
| 20–25<br>-                          | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                |
| 26–31<br>Collision_Window           | This is a programmable field representing the slot time or collision window during which collisions occur in properly configured networks. Because the collision window starts at the beginning of transmission, the preamble and SFD are included. Its default of 0x37 (55d) corresponds to the count of frame bytes at the end of the window. |

# 15.5.47 Maximum frame length (eTSECx\_MAXFRM)

The MAXFRM register is written by the user. See MAC functionality for more details.

Address: Base address + 510h offset



#### eTSECx\_MAXFRM field descriptions

| Field                  | Description                                                                                                                                                                                                                                                                                  |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-              | This field is reserved. Reserved                                                                                                                                                                                                                                                             |
| 16–31<br>Maximum_Frame | By default this field is set to 0x0600 (1536 bytes) . It sets the maximum Ethernet frame size in both the transmit and receive directions . (Refer to MACCFG2[Huge Frame].) Minimum value of MAXFRM is 64 bytes (0x0040). Maximum value is 9600 bytes (0x2580).                              |
|                        | Note that if MACCFG2[Huge_Frame] = 0, the value of this field must be less than or equal to MRBLR[MRBL] x (minimum number of RxBDs per ring). See MAC configuration register 2 (eTSEC_MACCFG2), Maximum receive buffer length register (eTSEC_MRBLR), and Receive buffer descriptors (RxBD). |

# 15.5.48 Interface status (eTSECx\_IFSTAT)

See MAC functionality for more details.

#### eTSEC memory map/register definition Address: Base address + 53Ch offset Bit R Reserved W Reset Bit Excess\_Defer R Reserved Reserved W Reset

## eTSECx\_IFSTAT field descriptions

| Field              | Description                                                                                                                                                                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–21               | This field is reserved. Reserved                                                                                                                                                                                                                                   |
| 22<br>Excess_Defer | Excessive transmission defer . This bit latches high and is cleared when read . This bit is cleared by default.  0 Normal operation.  1 A transmit frame has been excessively deferred (6,071 nibble-times in 100 Mbps modes or 24,287 bit-times in 10 Mbps modes) |
| 23–31<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                   |

# 15.5.49 MAC station address register 1 (eTSECx\_MACSTNADDR1)

The MACSTNADDR1 register is written by the user. The value of the station address written into MACSTNADDR1 and MACSTNADDR2 is byte reversed from how it would appear in the DA field of a frame in memory . For example, for a station address of 0x1234\_5678\_ABCD, MACSTNADDR1 is set to 0xCDAB\_7856 and MACSTNADDR2 is set to 0x3412\_0000 . See MAC functionality for more details.



| Bit    | 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  |
|--------|-----|-------|-----|------|------|-----|-----|-----|----|-------|-----|------|-----|------|-----|-----|----|-------|-----|------|------|------|-----|-----|----|------|-----|------|------|------|-----|-----|
| R<br>W | Sta | atior | 1_A | ddre | ess_ | 6th | _Oc | tet | St | atior | า_A | ddre | ss_ | 5th_ | _Oc | tet | St | atior | า_A | ddre | ess_ | 4th_ | _Oc | tet | St | atio | n_A | ddre | ess_ | 3rd_ | Oct | tet |
| Reset  | 0   | 0     | 0   | 0    | 0    | 0   | 0   | 0   | 0  | 0     | 0   | 0    | 0   | 0    | 0   | 0   | 0  | 0     | 0   | 0    | 0    | 0    | 0   | 0   | 0  | 0    | 0   | 0    | 0    | 0    | 0   | 0   |

### eTSECx\_MACSTNADDR1 field descriptions

| Field                                  | Description                                                                                                                         |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0-7<br>Station_Address_<br>6th_Octet   | This field holds the sixth octet of the station address. The sixth octet (station address bits 40-47) defaults to a value of 0x0.   |
| 8–15<br>Station_Address_<br>5th_Octet  | This field holds the fifth octet of the station address. The fifth octet (station address bits 32-39) defaults to a value of 0x0.   |
| 16–23<br>Station_Address_<br>4th_Octet | This field holds the fourth octet of the station address. The fourth octet (station address bits 24-31) defaults to a value of 0x0. |
| 24–31<br>Station_Address_<br>3rd_Octet | This field holds the third octet of the station address. The third octet (station address bits 16-23) defaults to a value of 0x0.   |

# 15.5.50 MAC station address register 2 (eTSECx\_MACSTNADDR2)

The MACSTNADDR2 register is written by the user. See MAC functionality for more details.

Address: Base address + 544h offset

| Bit    | 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 |
|--------|----------------------------------------------------------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R<br>W | R Station_Address_2nd_Octet Station_Address_1st_Octet Reserved |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset  | 0                                                              | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### eTSECx\_MACSTNADDR2 field descriptions

| Field                                 | Description                                                                                                                        |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>Station_Address_<br>2nd_Octet  | This field holds the second octet of the station address. The second octet (station address bits 8-15) defaults to a value of 0x0. |
| 8–15<br>Station_Address_<br>1st_Octet | This field holds the first octet of the station address. The first octet (station address bits 0-7) defaults to a value of 0x0.    |
| 16–31<br>-                            | This field is reserved. Reserved                                                                                                   |

# 15.5.51 MAC exact match address n, part 1 \* (eTSECx\_MACnADDR1)

The MAC01ADDR1-MAC15ADDR1 registers are written by the user with the unicast or multicast addresses aliasing the MAC. The value of the address written into MAC *n* ADDR1 and MAC *n* ADDR2 is byte reversed from how it would appear in the DA field of a frame in memory. For example, for a MAC address of 0x1234\_5678\_ABCD, MACnADDR1 is set to 0xCDAB\_7856 and MAC *n* ADDR2 is set to 0x3412\_0000. For any valid, non-zero MAC address received, exact match registers can be excluded individually by clearing them to all zero bytes. See MAC functionality for more details.

Address: Base address + 548h offset + (8d  $\times$  i), where i=0d to 14d



### eTSECx\_MACnADDR1 field descriptions

| Field                                          | Description                                                                                                                      |
|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 0–7 Exact_Match_ Address_6th_ Octet            | Holds the sixth octet of the exact match address. The sixth octet (destination address bits 40-47) defaults to a value of 0x0.   |
| 8–15 Exact_Match_ Address_5th_ Octet           | Holds the fifth octet of the exact match address. The fifth octet (destination address bits 32-39) defaults to a value of 0x0.   |
| 16–23<br>Exact_Match_<br>Address_4th_<br>Octet | Holds the fourth octet of the exact match address. The fourth octet (destination address bits 24-31) defaults to a value of 0x0. |

#### eTSECx\_MACnADDR1 field descriptions (continued)

| Field | Description                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
|       | Holds the third octet of the exact match address. The third octet (destination address bits 16-23) defaults to a value of 0x0. |

# 15.5.52 MAC exact match address n, part 2 \* (eTSECx\_MACnADDR2)

The MAC01ADDR2-MAC15ADDR2 registers are written by the user with the unicast or multicast addresses aliasing the MAC. See MAC functionality for more details.

Address: Base address + 54Ch offset + (8d × i), where i=0d to 14d



#### eTSECx\_MACnADDR2 field descriptions

| Field                                         | Description                                                                                                                                |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 0-7 Exact_Match_ Address_2nd_ Octet           | This field holds the second octet of the exact match address. The second octet (destination address bits 8-15) defaults to a value of 0x0. |
| 8–15<br>Exact_Match_<br>Address_1st_<br>Octet | This field holds the first octet of the exact match address. The first octet (destination address bits 0-7) defaults to a value of 0x0.    |
| 16–31<br>-                                    | This field is reserved. Reserved                                                                                                           |

# 15.5.53 Transmit and receive 64-byte frame counter (eTSECx\_TR64)

See MIB registers for more details.

Address: Base address + 680h offset



#### eTSECx\_TR64 field descriptions

| Field         | Description                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>-      | This field is reserved. Reserved                                                                                                                                                                       |
| 10–31<br>TR64 | Transmit and receive 64-byte frame counter -Increment for each good or bad frame transmitted and received which is 64 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.54 Transmit and receive 65- to 127-byte frame counter (eTSECx\_TR127)

See MIB registers for more details.

Address: Base address + 684h offset



#### eTSECx\_TR127 field descriptions

| Field          | Description                                                                                                                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>-       | This field is reserved. Reserved                                                                                                                                                                                    |
| 10–31<br>TR127 | Transmit and receive 65- to 127-byte frame counter -Increments for each good or bad frame transmitted and received which is 65-127 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.55 Transmit and receive 128- to 255-byte frame counter (eTSECx\_TR255)

See MIB registers for more details.





### eTSECx\_TR255 field descriptions

| Field | Description                                                                                                                                                                                                           |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | This field is reserved. Reserved                                                                                                                                                                                      |
|       | Transmit and receive 128- to 255-byte frame counter -Increments for each good or bad frame transmitted and received which is 128-255 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.56 Transmit and receive 256- to 511-byte frame counter (eTSECx\_TR511)

See MIB registers for more details.

#### Address: Base address + 68Ch offset



### eTSECx\_TR511 field descriptions

| Field | Description                                                                                                                                                      |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9   | This field is reserved. Reserved                                                                                                                                 |
|       | Increments for each good or bad frame transmitted and received which is 256-511 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.57 Transmit and receive 512- to 1023-byte frame counter (eTSECx\_TR1K)

See MIB registers for more details.

Address: Base address + 690h offset



### eTSECx\_TR1K field descriptions

| Field | Description                                                                                                                                                       |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9   | This field is reserved. Reserved                                                                                                                                  |
|       | Increments for each good or bad frame transmitted and received which is 512-1023 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.58 Transmit and receive 1024- to 1518-byte frame counter (eTSECx\_TRMAX)

See MIB registers for more details.

Address: Base address + 694h offset



#### eTSECx\_TRMAX field descriptions

| Field | Description                                                                                                                                                        |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9   | This field is reserved. Reserved                                                                                                                                   |
|       | Increments for each good or bad frame transmitted and received which is 1024-1518 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

# 15.5.59 Transmit and receive 1519- to 1522-byte good VLAN frame count (eTSECx\_TRMGV)

See MIB registers for more details.





### eTSECx\_TRMGV field descriptions

| Field    | Description                                                                                                                                                        |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>- | This field is reserved. Reserved                                                                                                                                   |
|          | Increments for each good or bad frame transmitted and received which is 1519-1522 bytes in length, inclusive (excluding preamble and SFD but including FCS bytes). |

## 15.5.60 Receive byte counter (eTSECx\_RBYT)

See MIB registers for more details.

Address: Base address + 69Ch offset



## eTSECx\_RBYT field descriptions

| Field | Description                                                                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31  | Receive byte counter                                                                                                                                                 |
| RBYT  | The statistic counter register increments by the byte count of frames received , including those in bad packets, excluding preamble and SFD but including FCS bytes. |

## 15.5.61 Receive packet counter (eTSECx\_RPKT)

See MIB registers for more details.





#### eTSECx\_RPKT field descriptions

| Field         | Description                                                                                                                               |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>-      | This field is reserved. Reserved                                                                                                          |
| 10–31<br>RPKT | Receive packet counter  Increments for each frame received packet (including bad packets, all unicast, broadcast, and multicast packets). |

# 15.5.62 Receive FCS error counter (eTSECx\_RFCS)

See MIB registers for more details.

Address: Base address + 6A4h offset



#### eTSECx\_RFCS field descriptions

| Field         | Description                                                                                                                         |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                    |
| 16–31<br>RFCS | Receive FCS error counter                                                                                                           |
| HFC3          | In Ethernet mode, increments for each frame received that has an integral 64-1518 length and contains a frame check sequence error. |

## 15.5.63 Receive multicast packet counter (eTSECx\_RMCA)

See MIB registers for more details.





#### eTSECx\_RMCA field descriptions

| Field         | Description                                                                                                                                                                                                            |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>-      | This field is reserved. Reserved                                                                                                                                                                                       |
| 10–31<br>RMCA | Receive multicast packet counter  Increments for each multicast frame with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN), excluding broadcast frames. This count does not include range/length errors. |

# 15.5.64 Receive broadcast packet counter (eTSECx\_RBCA)

See MIB registers for more details.

#### Address: Base address + 6ACh offset



#### eTSECx\_RBCA field descriptions

| Field    | Description                                                                                                                                                                                                  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9<br>- | This field is reserved. Reserved                                                                                                                                                                             |
| RBCA     | Receive broadcast packet counter  Increments for each broadcast frame with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN), excluding multicast frames . Does not include range/length errors. |

## 15.5.65 Receive control frame packet counter (eTSECx\_RXCF)

See MIB registers for more details.

Address: Base address + 6B0h offset



## eTSECx\_RXCF field descriptions

| Field         | Description                                                                                                                                                                     |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                |
| 16–31<br>RXCF | Receive control frame packet counter Increments for each MAC control frame received (PAUSE and unsupported) with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

## 15.5.66 Receive PAUSE frame packet counter (eTSECx\_RXPF)

See MIB registers for more details.

Address: Base address + 6B4h offset



#### eTSECx\_RXPF field descriptions

| Field     | Description                                                                                                                                                         |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                    |
| 1         | Receive PAUSE frame packet counter . Increments each time a PAUSE MAC control frame is received with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

## 15.5.67 Receive unknown OP code counter (eTSECx\_RXUO)

See MIB registers for more details.





#### eTSECx\_RXUO field descriptions

| Field     | Description                                                                                                                                                                                                   |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                                                              |
|           | Receive unknown opcode counter . Increments each time a MAC control frame is received which contains an opcode other than PAUSE, but the frame has valid CRC and length 64 to 1518 (non VLAN) or 1522 (VLAN). |

## 15.5.68 Receive alignment error counter (eTSECx\_RALN)

See MIB registers for more details.

#### Address: Base address + 6BCh offset



#### eTSECx\_RALN field descriptions

| Field     | Description                                                                                                                                                                          |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                                     |
|           | Receive alignment error counter . Increments for each received frame from 64 to 1518 (non VLAN) or 1522 (VLAN) which contains an invalid FCS and is not an integral number of bytes. |

## 15.5.69 Receive frame length error counter (eTSECx\_RFLR)

See MIB registers for more details.

Address: Base address + 6C0h offset



#### eTSECx\_RFLR field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                    |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                                                                                                                                               |
| RFLR      | Receive frame length error counter . Increments for each frame received in which the 802.3 length field did not match the number of data bytes actually received (46-1500 bytes) . The counter does not increment if the length field is not a valid 802.3 length, such as an Ethertype value. |

## 15.5.70 Receive code error counter (eTSECx\_RCDE)

See MIB registers for more details.

Address: Base address + 6C4h offset



### eTSECx\_RCDE field descriptions

| Field     | Description                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                               |
|           | Receive code error counter . Increments each time a valid carrier is present and at least one invalid data symbol is detected. |

## 15.5.71 Receive carrier sense error counter (eTSECx\_RCSE)

See MIB registers for more details.





#### eTSECx\_RCSE field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                              |
| 16–31<br>RCSE | Receive false carrier counter. Counts the number of times that the carrier sense condition was lost or never asserted when attempting to transmit a frame on a particular interface.                                                                                                                                                                                                                                          |
|               | The count represented by an instance of this object is incremented at most once per transmission attempt, even if the carrier sense condition fluctuates during a transmission attempt. The event is reported along with the statistics generated on the next received frame , as defined by a 1 on TSEC $n$ _RX_ER and an 0xE on TSEC $n$ _RXD . Only one false carrier condition can be detected and logged between frames. |

# 15.5.72 Receive undersize packet counter (eTSECx\_RUND)

See MIB registers for more details.

#### Address: Base address + 6CCh offset



#### eTSECx\_RUND field descriptions

| Field     | Description                                                                                                                                                                                                                |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                                                                           |
| RUND      | Receive undersize packet counter. Increments each time a frame is received which is less than 64 bytes in length and contains a valid FCS and were otherwise well formed. This count does not include range length errors. |

## 15.5.73 Receive oversize packet counter (eTSECx\_ROVR)

See MIB registers for more details.

Address: Base address + 6D0h offset



#### eTSECx\_ROVR field descriptions

| Field         | Description                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                                  |
| 16–31<br>ROVR | Receive oversize packet counter . Increments each time a frame is received which exceeded 1518 (non VLAN) or 1522 (VLAN) and contains a valid FCS and was otherwise well formed . |

# 15.5.74 Receive fragments counter (eTSECx\_RFRG)

See MIB registers for more details.

Address: Base address + 6D4h offset



## eTSECx\_RFRG field descriptions

| Field     | Description                                                                                                                                                                         |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                                    |
|           | Receive fragments counter . Increments for each frame received which is less than 64 bytes in length and contains an invalid FCS . This includes integral and non-integral lengths. |

## 15.5.75 Receive jabber counter (eTSECx\_RJBR)

See MIB registers for more details.

Address: Base address + 6D8h offset



#### eTSECx\_RJBR field descriptions

| Field     | Description                                                                                                                                                            |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                                       |
|           | Receive jabber counter . Increments for frames received which exceed 1518 (non VLAN) or 1522 (VLAN) bytes and contain an invalid FCS . This includes alignment errors. |

# 15.5.76 Receive drop counter (eTSECx\_RDRP)

See MIB registers for more details.

Address: Base address + 6DCh offset



## eTSECx\_RDRP field descriptions

| Field     | Description                                                                                                                                          |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>- | This field is reserved. Reserved                                                                                                                     |
|           | Receive dropped packets counter . Increments for frames received which are streamed to system but are later dropped due to lack of system resources. |

## 15.5.77 Transmit byte counter (eTSECx\_TBYT)

See MIB registers for more details.





#### eTSECx\_TBYT field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Transmit byte counter. Increments by the number of bytes that were put on the wire including fragments of frames that were involved with collisions. This count does not include preamble/SFD or jam bytes.  Note that the value of TBYT may be greater than the actual number of bytes transmitted if the frame is truncated because it exceeds MAXFRM. |

## 15.5.78 Transmit packet counter (eTSECx\_TPKT)

See MIB registers for more details.

Address: Base address + 6E4h offset



## eTSECx\_TPKT field descriptions

| Field | Description                                                                                                                                                                                                               |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | This field is reserved. Reserved                                                                                                                                                                                          |
| TPKT  | Transmit packet counter . Increments for each transmitted packet (including bad packets, excessive deferred packets, excessive collision packets, late collision packets, all unicast, broadcast, and multicast packets). |

## 15.5.79 Transmit multicast packet counter (eTSECx\_TMCA)

See MIB registers for more details.





#### eTSECx\_TMCA field descriptions

| Field         | Description                                                                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9           | This field is reserved. Reserved                                                                                                                                                           |
| 10-31<br>TMCA | Transmit multicast packet counter . Increments for each multicast valid frame transmitted (excluding broadcast frames) with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

# 15.5.80 Transmit broadcast packet counter (eTSECx\_TBCA)

See MIB registers for more details.

Address: Base address + 6ECh offset



## eTSECx\_TBCA field descriptions

| Field         | Description                                                                                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9           | This field is reserved. Reserved                                                                                                                                                     |
| 10–31<br>TBCA | Transmit broadcast packet counter . Increments for each broadcast frame transmitted (excluding multicast frames) with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

## 15.5.81 Transmit PAUSE control frame counter (eTSECx\_TXPF)

See MIB registers for more details.





#### eTSECx\_TXPF field descriptions

| Field         | Description                                                                                                                                                                   |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                                                                                                              |
| 16–31<br>TXPF | Transmit PAUSE frame packet counter . Increments each time a valid PAUSE MAC control frame is transmitted with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

# 15.5.82 Transmit deferral packet counter (eTSECx\_TDFR)

See MIB registers for more details.

#### Address: Base address + 6F4h offset



## eTSECx\_TDFR field descriptions

| Field         | Description                                                                                                                                                                     |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                                                |
| 20–31<br>TDFR | Transmit deferral packet counter . Increments for each frame, which was deferred on its first transmission attempt . This count does not include frames involved in collisions. |

# 15.5.83 Transmit excessive deferral packet counter (eTSECx\_TEDF)

See MIB registers for more details.

Address: Base address + 6F8h offset



### eTSECx\_TEDF field descriptions

| Field         | Description                                                                                                                                      |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                 |
| 20–31<br>TEDF | Transmit excessive deferral packet counter. Increments for frames aborted which were deferred for an excessive period of time (3036 byte times). |

# 15.5.84 Transmit single collision packet counter (eTSECx\_TSCL)

See MIB registers for more details.

Address: Base address + 6FCh offset



## eTSECx\_TSCL field descriptions

| Field         | Description                                                                                                                                   |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                              |
| 20-31<br>TSCL | Transmit single collision packet counter . Increments for each frame transmitted which experienced exactly one collision during transmission. |

# 15.5.85 Transmit multiple collision packet counter (eTSECx\_TMCL)

See MIB registers for more details.

Address: Base address + 700h offset



### eTSECx\_TMCL field descriptions

| Field         | Description                                                                                                                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                                                                                                         |
| 20–31<br>TMCL | Transmit multiple collision packet counter . Increments for each frame transmitted which experienced 2-15 collisions (including any late collisions) during transmission as defined using the Half_Duplex[RETRANSMISSION MAXIMUM] field. |

# 15.5.86 Transmit late collision packet counter (eTSECx\_TLCL)

See MIB registers for more details.

Address: Base address + 704h offset



#### eTSECx\_TLCL field descriptions

| Field         | Description                                                                                                                                                                                                                                         |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                    |
| 20–31<br>TLCL | Transmit late collision packet counter . Increments for each frame transmitted which experienced a late collision during a transmission attempt . Late collisions are defined using the collision window field of the half-duplex [26-31] register. |

# 15.5.87 Transmit excessive collision packet counter (eTSECx\_TXCL)

See MIB registers for more details.





### eTSECx\_TXCL field descriptions

| Field     | Description                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>- | This field is reserved. Reserved                                                                                                            |
|           | Transmit excessive collision packet counter . Increments for each frame that experienced 16 collisions during transmission and was aborted. |

# 15.5.88 Transmit total collision counter (eTSECx\_TNCL)

See MIB registers for more details.

Address: Base address + 70Ch offset



## eTSECx\_TNCL field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                           |
| 20–31<br>TNCL | Transmit total collision counter . Increments by the number of collisions experienced during the transmission of a frame as defined by the assertion of COL, or for protocols without COL ,or the simultaneous assertion of TX_EN and RX_DV, or their equivalents (that is, transmitting and receiving at the same time) . |
|               | NOTE: This count does not include collisions that result in an excessive collision condition.                                                                                                                                                                                                                              |

## 15.5.89 Transmit drop frame counter (eTSECx\_TDRP)

See MIB registers for more details.





#### eTSECx\_TDRP field descriptions

| Field         | Description                                                                                    |
|---------------|------------------------------------------------------------------------------------------------|
| 0–15<br>-     | This field is reserved. Reserved                                                               |
| 16–31<br>TDRP | Transmit drop frame counter . Increments each time a memory error or an underrun has occurred. |

# 15.5.90 Transmit jabber frame counter (eTSECx\_TJBR)

See MIB registers for more details.

Address: Base address + 718h offset



## eTSECx\_TJBR field descriptions

| Field         | Description                                                                                                  |
|---------------|--------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                             |
| 20–31<br>TJBR | Transmit jabber frame counter . Increments for each oversized transmitted frame with an incorrect FCS value. |

## 15.5.91 Transmit FCS error counter (eTSECx\_TFCS)

See MIB registers for more details.

Address: Base address + 71Ch offset



#### eTSECx\_TFCS field descriptions

| Field         | Description                                                                                       |
|---------------|---------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                  |
| 20-31<br>TFCS | Transmit FCS error counter . Increments for every valid sized packet with an incorrect FCS value. |

# 15.5.92 Transmit control frame counter (eTSECx\_TXCF)

See MIB registers for more details.

Address: Base address + 720h offset



## eTSECx\_TXCF field descriptions

| Field         | Description                                                                                                                             |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                        |
| 20–31<br>TXCF | Transmit control frame counter . Increments for every control frame with valid CRC and of lengths 64 to 1518 (non VLAN) or 1522 (VLAN). |

## 15.5.93 Transmit oversize frame counter (eTSECx\_TOVR)

See MIB registers for more details.





#### eTSECx\_TOVR field descriptions

| Field         | Description                                                                                                                                              |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                                                                         |
| 20–31<br>TOVR | Transmit oversize frame counter. Increments each time a frame is transmitted ^M which exceeded 1518 (non VLAN) or 1522 (VLAN) with a correct FCS value . |

# 15.5.94 Transmit undersize frame counter (eTSECx\_TUND)

See MIB registers for more details.

Address: Base address + 728h offset



## eTSECx\_TUND field descriptions

| Field         | Description                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                            |
| 20–31<br>TUND | Transmit undersize frame counter . Increments for every frame less then 64 bytes, with a correct FCS value. |

# 15.5.95 Transmit fragments frame counter (eTSECx\_TFRG)

See MIB registers for more details.





#### eTSECx\_TFRG field descriptions

| Field         | Description                                                                                             |
|---------------|---------------------------------------------------------------------------------------------------------|
| 0–19<br>-     | This field is reserved. Reserved                                                                        |
| 20–31<br>TFRG | Transmit fragment counter . Increments for every frame less then 64 bytes, with an incorrect FCS value. |

# 15.5.96 Carry register one (eTSECx\_CAR1)

Carry register bits are cleared on carry register writes when the respective bits are set . See MIB registers for more details.



eTSECx\_CAR1 field descriptions

| Field      | Description                              |
|------------|------------------------------------------|
| 0<br>C164  | Carry register 1 TR64 counter carry bit  |
| 1<br>C1127 | Carry register 1 TR127 counter carry bit |
| 2<br>C1255 | Carry register 1 TR255 counter carry bit |
| 3<br>C1511 | Carry register 1 TR511 counter carry bit |
| 4<br>C11K  | Carry register 1 TR1K counter carry bit  |
| 5<br>C1MAX | Carry register 1 TRMAX counter carry bit |

Table continues on the next page...

# eTSECx\_CAR1 field descriptions (continued)

| Field       | Description                              |
|-------------|------------------------------------------|
| 6<br>C1MGV  | Carry register 1 TRMGV counter carry bit |
| 7–13<br>-   | This field is reserved. Reserved         |
| 14<br>C1REJ | Carry register 1 RREJ counter carry bit  |
| 15<br>C1RBY | Carry register 1 RBYT counter carry bit  |
| 16<br>C1RPK | Carry register 1 RPKT counter carry bit  |
| 17<br>C1RFC | Carry register 1 RFCS counter carry bit  |
| 18<br>C1RMC | Carry register 1 RMCA counter carry bit  |
| 19<br>C1RBC | Carry register 1 RBCA counter carry bit  |
| 20<br>C1RXC | Carry register 1 RXCF counter carry bit  |
| 21<br>C1RXP | Carry register 1 RXPF counter carry bit  |
| 22<br>C1RXU | Carry register 1 RXUO counter carry bit  |
| 23<br>C1RAL | Carry register 1 RALN counter carry bit  |
| 24<br>C1RFL | Carry register 1 RFLR counter carry bit  |
| 25<br>C1RCD | Carry register 1 RCDE counter carry bit  |
| 26<br>C1RCS | Carry register 1 RCSE counter carry bit  |
| 27<br>C1RUN | Carry register 1 RUND counter carry bit  |
| 28<br>C1ROV | Carry register 1 ROVR counter carry bit  |
| 29<br>C1RFR | Carry register 1 RFRG counter carry bit  |
| 30<br>C1RJB | Carry register 1 RJBR counter carry bit  |
| 31<br>C1RDR | Carry register 1 RDRP counter carry bit  |

# 15.5.97 Carry register two (eTSECx\_CAR2)

Carry register bits are cleared on carry register write when the respective bits are set. See MIB registers for more details.



# eTSECx\_CAR2 field descriptions

| Field       | Description                                         |
|-------------|-----------------------------------------------------|
| 0–11        | This field is reserved. Reserved                    |
| 12<br>C2TJB | Carry register 2 TJBR counter carry bit             |
| 13<br>C2TFC | Carry register 2 TFCS counter carry bit             |
| 14<br>C2TCF | Carry register 2 TXCF counter carry bit             |
| 15<br>C2TOV | Carry register 2 TOVR counter carry bit             |
| 16<br>C2TUN | Carry register 2 TUND counter carry bit             |
| 17<br>C2TFG | Carry register 2 TFRG counter carry bit             |
| 18<br>C2TBY | Carry register 2 TBYT counter carry bit             |
| 19<br>C2TPK | Carry register 2 TPKT counter carry bit             |
| 20<br>C2TMC | Carry register 2 TMCA counter carry bit             |
| 21<br>C2TBC | Carry register 2 TBCA counter carry bit             |
| 22<br>C2TPF | Carry register 2 TXPF counter carry bit             |
| 23<br>C2TDF | Carry register 2 TDFR counter carry bit             |
| 24<br>C2TED | Carry register 2 TEDF counter carry bit             |
| 25<br>C2TSC | Carry register 2 TSCL counter carry bit             |
| 26<br>C2TMA | Carry register 2 TMCL counter carry bit             |
| 27<br>C2TLC | Carry register 2 TLCL counter carry bit             |
| 28<br>C2TXC | Carry register 2 TXCL counter carry bit             |
| 29<br>C2TNC | Carry register 2 TNCL counter carry bit             |
| 30          | This field is reserved. Reserved, should be cleared |
| 31<br>C2TDP | Carry register 2 TDRP counter carry bit             |

# 15.5.98 Carry register one mask register (eTSECx\_CAM1)

While one of the below mask bits are cleared, the corresponding carry bit in CAR1 is allowed to cause interrupt indications in register IEVENTG g [MSRO]. These bits all default to a set state. See MIB registers for more details.



## eTSECx\_CAM1 field descriptions

| Field       | Description                                  |
|-------------|----------------------------------------------|
| 0<br>M164   | Mask register 1 TR64 counter carry bit mask  |
| 1<br>M1127  | Mask register 1 TR127 counter carry bit mask |
| 2<br>M1255  | Mask register 1 TR255 counter carry bit mask |
| 3<br>M1511  | Mask register 1 TR511 counter carry bit mask |
| 4<br>M11K   | Mask register 1 TR1K counter carry bit mask  |
| 5<br>M1MAX  | Mask register 1 TRMAX counter carry bit mask |
| 6<br>M1MGV  | Mask register 1 TRMGV counter carry bit mask |
| 7–13<br>-   | This field is reserved. Reserved             |
| 14<br>M1REJ | Mask register 1 RREJ counter carry bit mask  |
| 15<br>M1RBY | Mask register 1 RBYT counter carry bit mask  |

Table continues on the next page...

# eTSECx\_CAM1 field descriptions (continued)

| Field       | Description                                 |
|-------------|---------------------------------------------|
| 16<br>M1RPK | Mask register 1 RPKT counter carry bit mask |
| 17<br>M1RFC | Mask register 1 RFCS counter carry bit mask |
| 18<br>M1RMC | Mask register 1 RMCA counter carry bit mask |
| 19<br>M1RBC | Mask register 1 RBCA counter carry bit mask |
| 20<br>M1RXC | Mask register 1 RXCF counter carry bit mask |
| 21<br>M1RXP | Mask register 1 RXPF counter carry bit mask |
| 22<br>M1RXU | Mask register 1 RXUO counter carry bit mask |
| 23<br>M1RAL | Mask register 1 RALN counter carry bit mask |
| 24<br>M1RFL | Mask register 1 RFLR counter carry bit mask |
| 25<br>M1RCD | Mask register 1 RCDE counter carry bit mask |
| 26<br>M1RCS | Mask register 1 RCSE counter carry bit mask |
| 27<br>M1RUN | Mask register 1 RUND counter carry bit mask |
| 28<br>M1ROV | Mask register 1 ROVR counter carry bit mask |
| 29<br>M1RFR | Mask register 1 RFRG counter carry bit mask |
| 30<br>M1RJB | Mask register 1 RJBR counter carry bit mask |
| 31<br>M1RDR | Mask register 1 RDRP counter carry bit mask |

## 15.5.99 Carry register two mask register (eTSECx\_CAM2)

While one of the below mask bits are cleared, the corresponding carry bit in CAR2 is allowed to cause interrupt indications in register IEVENTG *g* [MSRO]. These bits default to a set state. See MIB registers for more details.



eTSECx\_CAM2 field descriptions

| Field       | Description                                 |
|-------------|---------------------------------------------|
| 0–11<br>-   | This field is reserved. Reserved            |
| 12<br>M2TJB | Mask register 2 TJBR counter carry bit mask |
| 13<br>M2TFC | Mask register 2 TFCS counter carry bit mask |
| 14<br>M2TCF | Mask register 2 TXCF counter carry bit mask |
| 15<br>M2TOV | Mask register 2 TOVR counter carry bit mask |
| 16<br>M2TUN | Mask register 2 TUND counter carry bit mask |

Table continues on the next page...

## eTSECx\_CAM2 field descriptions (continued)

| Field       | Description                                 |
|-------------|---------------------------------------------|
| 17<br>M2TFG | Mask register 2 TFRG counter carry bit mask |
| 18<br>M2TBY | Mask register 2 TBYT counter carry bit mask |
| 19<br>M2TPK | Mask register 2 TPKT counter carry bit mask |
| 20<br>M2TMC | Mask register 2 TMCA counter carry bit mask |
| 21<br>M2TBC | Mask register 2 TBCA counter carry bit mask |
| 22<br>M2TPF | Mask register 2 TXPF counter carry bit mask |
| 23<br>M2TDF | Mask register 2 TDFR counter carry bit mask |
| 24<br>M2TED | Mask register 2 TEDF counter carry bit mask |
| 25<br>M2TSC | Mask register 2 TSCL counter carry bit mask |
| 26<br>M2TMA | Mask register 2 TMCL counter carry bit mask |
| 27<br>M2TLC | Mask register 2 TLCL counter carry bit mask |
| 28<br>M2TXC | Mask register 2 TXCL counter carry bit mask |
| 29<br>M2TNC | Mask register 2 TNCL counter carry bit mask |
| 30<br>-     | This field is reserved. Reserved            |
| 31<br>M2TDP | Mask register 2 TDRP counter carry bit mask |

# 15.5.100 Receive filer rejected packet counter \* (eTSECx\_RREJ)

See MIB registers for more details.

Address: Base address + 740h offset



#### eTSECx\_RREJ field descriptions

| Field | Description                                                                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–9   | This field is reserved. Reserved                                                                                                                                                                                                                                                 |
| RREJ  | Receive filer rejected packet counter . Increments for each frame with valid CRC received, but rejected by the receive queue filer-either due to a matching rule that asserted the REJ flag or due to filing to a RxBD ring that was not enabled (see IEVENTG $g$ [FIQ] error) . |

# 15.5.101 Individual/group address register n (eTSECx\_IGADDRn)

The IGADDR *n* registers are written by the user . Together these registers represent, depending on RCTRL[GHTX], either the 256 entries of the individual address hash table, or the first 256 entries of the extended group address hash table used in the address recognition process . The user can enable a hash entry by setting the appropriate bit . A hash table hit occurs if the DA CRC-32 result points to an enabled hash entry . See Hash function registers for more details.

Address: Base address + 800h offset + (4d  $\times$  i), where i=0d to 7d



## eTSECx\_IGADDRn field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                       |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IGADDRn | Represents the 32-bit value associated with the corresponding register. When RCTRL[GHTX] = 0, IGADDR0 contains entries 0-31 of the 256-entry individual hash table and IGADDR7 represents entries 224-255. When RCTRL[GHTX] = 1, IGADDR0 contains entries 0-31 of the 512-entry extended group hash table and IGADDR7 represents entries 224-255. |

## 15.5.102 Group address register n (eTSECx\_GADDRn)

The GADDR *n* registers are written by the user . Together these registers represent, depending on RCTRL[GHTX], either the 256 entries of the group address hash table, or the last 256 entries of the extended group address hash table used in the address recognition process . The user can enable a hash entry by setting the appropriate bit . A hash table hit occurs if the DA CRC result points to an enabled hash entry . See Hash function registers for more details.





## eTSECx\_GADDRn field descriptions

| Field  | Description                                                                                                                                                                                                                                                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GADDRn | Represents the 32-bit value associated with the corresponding register. When RCTRL[GHTX] = 0, GADDR0 contains entries 0-31 of the 256-entry group hash table and GADDR7 represents entries 224-255. When RCTRL[GHTX] = 1, GADDR0 contains entries 256-287 of the 512-entry extended group hash table and GADDR7 represents entries 480-511. |

# 15.5.103 Attribute register (eTSECx\_ATTR)

The attribute register defines memory access attributes and transaction types used to access buffer descriptors, to write receive data, and to read transmit data . Snoop enable attributes may be set for reading buffer descriptors and for reading transmit data . Buffer descriptors may be written with attributes that cause allocation into the L2 cache. Similarly, broad sections of a receive frame header may have attributes attached that cause allocation in the L2 cache . This process of specifying a region of each frame to stash into the L2 cache is referred to as *extraction*, which is specified in conjunction with register ATTRELI . ATTR[ELCWT] only has meaning if ATTRELI[EL] is non-zero. It is important to note that even though portions of received frames may be stashed to L2 cache, this is only a performance optimization as entire frames are still written to off-chip memory regardless of settings in ATTR.

#### eTSEC memory map/register definition

Address: Base address + BF8h offset



## eTSECx\_ATTR field descriptions

| Field          | Description                                                                                                                                                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                             |
| 17–18<br>ELCWT | Extracted L2 cache write type . Specifies the write transaction type to perform for the extracted data . For maximum performance, it is recommended that if ELCWT is set to allocate, BDLWT should also be set to allocate. Writes to cache are always performed with snoop. |
|                | 00 No allocation performed.                                                                                                                                                                                                                                                  |
|                | 01 Reserved                                                                                                                                                                                                                                                                  |
|                | 10 Allocate L2 cache line.                                                                                                                                                                                                                                                   |
|                | 11 Reserved.                                                                                                                                                                                                                                                                 |
| 19             | This field is reserved.                                                                                                                                                                                                                                                      |
| -              | Reserved                                                                                                                                                                                                                                                                     |
| 20–21<br>BDLWT | Buffer descriptor L2 cache write type . specifies the write transaction type to perform for the buffer descriptor for a receive frame . Writes to cache are always performed with snoop.                                                                                     |
|                | 00 No allocation performed.                                                                                                                                                                                                                                                  |
|                | 01 Reserved                                                                                                                                                                                                                                                                  |
|                | 10 Allocate L2 cache line.                                                                                                                                                                                                                                                   |
|                | 11 Reserved.                                                                                                                                                                                                                                                                 |
| 22–23          | This field is reserved.                                                                                                                                                                                                                                                      |
| -              | Reserved                                                                                                                                                                                                                                                                     |
| 24<br>RDSEN    | Rx data snoop enable .                                                                                                                                                                                                                                                       |

Table continues on the next page...

## eTSECx\_ATTR field descriptions (continued)

| Field  | Description                                                                                     |
|--------|-------------------------------------------------------------------------------------------------|
|        | 0 Disables snooping of all receive frames data to memory unless ELCWT specifies L2 allocation . |
|        | 1 Enables snooping of all receive frames data to memory.                                        |
| 25     | RxBD snoop enable .                                                                             |
| RBDSEN |                                                                                                 |
|        | 0 Disables snooping of all receive BD memory accesses unless BDLWT specifies L2 allocation .    |
|        | 1 Enables snooping of all receive BD memory accesses.                                           |
| 26–31  | This field is reserved.                                                                         |
| -      | Reserved                                                                                        |

# 15.5.104 Attribute extract length and extract index register \* (eTSECx\_ATTRELI)

The ATTRELI registers are written by the user to specify the extract index and extract length for extracting received frames. The extract length is typically set to the expected length of extracted packet headers.

Address: Base address + BFCh offset



#### eTSECx\_ATTRELI field descriptions

| Field       | Description                                                                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 2–12<br>EL  | Extracted length . Specifies the number of bytes, as a multiple of 8 bytes, to extract from the receive frame . The DMA controller uses this field to perform extraction. If cleared, no extraction is performed.                                                                       |
| 13–15<br>-  | This field is reserved.  To ensure that EL is a multiple of 8 bytes, these bits should be written with zero.                                                                                                                                                                            |
| 16–17<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                        |
| 18–25<br>El | Extracted index . Points to the first byte, as a multiple of 64 bytes, within the receive frame as sent to memory from which to begin extracting data. Editor note: receive frame as sent to memory includes any FCB, PAL, time-stamp, extracted Rx preamble, and end-of-frame padding. |
| 26–31<br>-  | This field is reserved.  To ensure that EI is a multiple of 8 bytes, these bits should be written with zero.                                                                                                                                                                            |

# 15.5.105 Receive Queue Parameters register n \* (eTSECx\_RQPRMn)

The RQPRM *n* registers specify the minimum number of BDs required to prevent flow control being asserted and the total number of Rx BDs in their respective ring. Whenever the free BD count calculated by the eTSEC for any active ring drops below the value of RQPRM *n* [FBTHR] for that ring, link level flow control is asserted. Software must not write to RQPRM *n* while LFC is enabled and the eTSEC is actively receiving frames. However, software may modify these registers after disabling LFC by clearing RCTRL[LFC]. Note that packets may be lost due to lack of RxBDs while RCTRL[LFC] is clear. Software can prevent packet loss by manually generating pause frames (through TCTRL[TFC\_PAUSE]) to cover the time when RCTRL[LFC] is clear. See Lossless flow control configuration registers for more details.

Address: Base address + C00h offset + (4d × i), where i=0d to 7d



## eTSECx\_RQPRMn field descriptions

| Field       | Description                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | Free BD threshold. Minimum number of buffer descriptors required for normal operation. If the eTSEC calculated number of free buffer descriptors drops below this threshold, link layer flow control is asserted. |
| 8–31<br>LEN | Ring length. Total number of Rx buffer descriptors in this ring.                                                                                                                                                  |

# 15.5.106 Last Free RxBD pointer for ring n \* (eTSECx\_RFBPTRn)

The RFBPTR *n* registers specify the location of the last free buffer descriptor in their respective ring. These registers live in the same 32b address space, and must share the same 4 most significant bits, as RBPTR *n*. That is, RFBPTR *n* and its associated RBPTR *n* must remain in the same 256MB page. Like RBPTR *n*, whenever RBASE *n* is updated, RFBPTR *n* is initialized to the value of RBASE *n*. This indicates that the ring is completely empty. As buffers are freed and their respective BDs are returned (by setting the EMPTY bit) to the ring, software is expected to update this register. The eTSEC then performs modulo arithmetic involving RBASE *n*, RBPTR *n* and RFBPTR *n* to determine the number of free BDs remaining in the ring. If at any stage the value written to RFBPTR *n* matches that of the respective RBPTR *n*, the eTSEC free BD calculation assumes that the ring is now completely empty.

For more information on the recommended use of these registers, see Back pressure determination through free buffers. See Lossless flow control configuration registers for more details.





#### eTSECx\_RFBPTRn field descriptions

| Field          | Description                                                                                                                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–28<br>RFBPTR | Pointer to the last free BD in RxBD Ring n. When RBASEn is updated, eTSEC initializes RFBPTR $n$ to the value in the corresponding RBASE $n$ .                                                  |
|                | Software may update this register at any time to inform the eTSEC the location of the last free BD in the ring. Note that the 3 least-significant bits of this register are read only and zero. |
| 29–31<br>-     | This field is reserved. Reserved.                                                                                                                                                               |

## 15.5.107 Interrupt steering register group n (eTSECx\_ISRGn)

These registers allow software to steer interrupt sources from any enabled ring to group g. When all bits in all the ISRG g are 0, then eTSEC operates in a backward-compatible single-group mode, in which all interrupts are steered to group 0 and RXIC and TXIC control interrupt coalescing for all rings. When any bits in the ISRG g registers are set, this puts the eTSEC into multi-group mode.

#### eTSEC memory map/register definition

Note that unlike the other per-group registers, ISRG *g* are implemented with a unique instance, with all n registers accessible through aliased register accesses from any group 4 Kbyte address region.

Note that it is illegal and unsupported to set bits that have the same position across different ISRG g. For example, it is illegal to set ISRG0[RR1] and ISRG1[RR1] at the same time. If any ISRG g [RR r or TR r] is set, it is also illegal to not set RR r or TR r but enable the corresponding ring. The results are boundedly undefined if either rule is violated.

Any bit set in any ISRG g enables multiple-group mode, including per ring interrupt coalescing and MWRR transmit scheduling of ring 0 (see Modified weighted round-robin queuing (MWRR)). Note that the BSY error interrupt is also routed based on the setting of ISRG g registers. See Interrupt steering and coalescing registers for more details.



## eTSECx\_ISRGn field descriptions

| Field    | Description                                                                                                                  |
|----------|------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RR0 | Rx Ring 0. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 0 to group $g$ . |
| 1<br>RR1 | Rx Ring 1. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 1 to group $g$ . |
| 2<br>RR2 | Rx Ring 2. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 2 to group $g$ . |
| 3<br>RR3 | Rx Ring 3. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 3 to group $g$ . |
| 4<br>RR4 | Rx Ring 4. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 4 to group $g$ . |
| 5<br>RR5 | Rx Ring 5. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 5 to group $g$ . |
| 6<br>RR6 | Rx Ring 6. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 6 to group $g$ . |
| 7<br>RR7 | Rx Ring 7. This field when set will steer all Rx interrupts and BSY error interrupt associated with Rx ring 7 to group $g$ . |
| 8<br>TR0 | Tx Ring 0. This field when set will steer all tx interrupts associated with tx ring 0 to group $g$ .                         |
| 9<br>TR1 | Tx Ring 1. This field when set will steer all tx interrupts associated with tx ring 1 to group $g$ .                         |

Table continues on the next page...

## **Chapter 15 Enhanced Three-Speed Ethernet Controllers**

# eTSECx\_ISRGn field descriptions (continued)

| Field      | Description                                                                                          |
|------------|------------------------------------------------------------------------------------------------------|
| 10<br>TR2  | Tx Ring 2. This field when set will steer all tx interrupts associated with tx ring 2 to group $g$ . |
| 11<br>TR3  | Tx Ring 3. This field when set will steer all tx interrupts associated with tx ring 3 to group $g$ . |
| 12<br>TR4  | Tx Ring 4. This field when set will steer all tx interrupts associated with tx ring 4 to group $g$ . |
| 13<br>TR5  | Tx Ring 5. This field when set will steer all tx interrupts associated with tx ring 5 to group $g$ . |
| 14<br>TR6  | Tx Ring 6. This field when set will steer all tx interrupts associated with tx ring 6 to group $g$ . |
| 15<br>TR7  | Tx Ring 7. This field when set will steer all tx interrupts associated with tx ring 7 to group $g$ . |
| 16–31<br>- | This field is reserved. Reserved                                                                     |

## 15.5.108 Ring n Rx interrupt coalescing (eTSECx\_RXICn)

The RXIC *r* register enables and configures the operational parameters for interrupt coalescing associated with received frames that are from ring 0. Note that RXIC0 is the same register as RXIC. RXIC1-7 have no function in single-group mode. They are in effect only when in multi-group mode. See Interrupt steering and coalescing registers for more details.



eTSECx\_RXICn field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ICEN | Interrupt coalescing enable                                                                                                                                                                                                                                                                                                    |
|           | 0 Interrupt coalescing is disabled for Rx ring r. Interrupts are raised as they are received.                                                                                                                                                                                                                                  |
|           | Interrupt coalescing is enabled for Rx ring $r$ . If the eTSEC receive frame interrupt is enabled (ISRG $g$ [RR $n$ ] = 1 and IMASKG $g$ [RXFEN] = 0), an interrupt is raised when the threshold number of frames is reached (defined by RXIC $r$ [ICFT]) or when the threshold timer expires (determined by RXIC $r$ [ICTT]). |
| 1<br>ICCS | Interrupt coalescing timer clock source .                                                                                                                                                                                                                                                                                      |
|           | <ul> <li>The coalescing timer advances count every 64 eTSEC Rx interface clocks (TSEC n _GTX_CLK).</li> <li>The coalescing timer advances count every 64 system clocks <sup>1</sup>.</li> </ul>                                                                                                                                |

Table continues on the next page...

## Chapter 15 Enhanced Three-Speed Ethernet Controllers

## eTSECx\_RXICn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 -           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3–10<br>ICFT  | Interrupt coalescing frame count threshold  While interrupt coalescing is enabled (RXIC $r$ [ICE] is set), this value determines how many frames are received before raising an interrupt . The eTSEC threshold counter is reset to ICFT following an interrupt . The value of ICFT must be greater than zero avoid unpredictable behavior .                                                                                                                                                                                                                                                                                                                                     |
| 11–15<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16–31<br>ICTT | Interrupt coalescing timer threshold While interrupt coalescing is enabled (RXIC $r$ [ICE] is set), this value determines the maximum amount of time after receiving a frame before raising an interrupt . If frames have been received but the frame count threshold has not been met, an interrupt is raised when the threshold timer reaches zero . The threshold timer is reset to the value in this field and begins counting down upon receiving the first frame having its RxBD[I] bit set . The threshold value is represented in units equal to 64 periods of the clock specified by RXIC $r$ [ICCS] . ICTT must be greater than zero to avoid unpredictable behavior . |

<sup>1.</sup> The term 'system clock' refers to CCB clock/2.

# 15.5.109 Ring n Tx interrupt coalescing (eTSECx\_TXICn)

The TXIC *r* register enables and configures the operational parameters for interrupt coalescing associated with transmitted frames that are in ring N. Note that TXIC0 is the same register as TXIC. TXIC1-7 have no function in single-group mode. They are in effect only when in multi-group mode. See Interrupt steering and coalescing registers for more details.



eTSECx\_TXICn field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ICEN | Interrupt coalescing enable                                                                                                                                                                                                                                                                                                    |
|           | 0 Interrupt coalescing is disabled on $Tx$ ring $r$ . Interrupts are raised as they are received.                                                                                                                                                                                                                              |
|           | 1 Interrupt coalescing is enabled on Tx ring N . If the eTSEC transmit frame interrupt is enabled (ISRG $g$ [TR $n$ ] = 1 and IMASKG $g$ [TXFEN] = 0), an interrupt is raised when the threshold number of frames is reached (defined by TXIC $r$ [ICFT]) or when the threshold timer expires (determined by TXIC $r$ [ICTT]). |
| 1<br>ICCS | Interrupt coalescing timer clock source.                                                                                                                                                                                                                                                                                       |
|           | <ul> <li>The coalescing timer advances count every 64 eTSEC Tx interface clocks (TSEC n _GTX_CLK).</li> <li>The coalescing timer advances count every 64 system clocks <sup>1</sup>.</li> </ul>                                                                                                                                |

## eTSECx\_TXICn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 -           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3–10<br>ICFT  | Interrupt coalescing frame count threshold While interrupt coalescing is enabled (TXIC $r$ [ICEN] is set), this value determines how many frames are transmitted before raising an interrupt . The eTSEC threshold counter is reset to ICFT following an interrupt . The value of ICFT must be greater than zero to avoid unpredictable behavior .                                                                                                                                                                                                                                                                                                                                                                        |
| 11–15<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16–31<br>ICTT | Interrupt coalescing timer threshold While interrupt coalescing is enabled (TXIC $r$ [ICEN] is set), this value determines the maximum amount of time after transmitting a frame before raising an interrupt . If frames have been transmitted but the frame count threshold has not been met, an interrupt is raised when the threshold timer reaches zero . The threshold timer is reset to the value in this field and begins counting down upon transmission of the first frame having its TxBD[I] bit set . The threshold value is represented in units of 64 clock periods as specified by the timer clock source (TXIC $n$ [ICCS[) . The value of ICTT must be greater than zero to avoid unpredictable behavior . |

<sup>1.</sup> The term 'system clock' refers to CCB clock/2.

# 15.6 eTSEC IEEE 1588 PTP memory map/register definition

This section lists the common IEEE 1588 PTP registers, which are located within the memory space for eTSEC1.

See Hardware assist for IEEE1588 compliant timestamping for more details.

### eTSEC1 memory map

| Offset<br>address<br>(hex) | Register name                                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0E00                     | Timer control register * (eTSEC1_1588_TMR_CTRL)                  | 32                 | R/W    | 0001_0001h  | 15.6.1/1048      |
| B_0E04                     | Time stamp event register * (eTSEC1_1588_TMR_TEVENT)             | 32                 | R/W    | 0000_0000h  | 15.6.2/1052      |
| B_0E08                     | Timer event mask register * (eTSEC1_1588_TMR_TEMASK)             | 32                 | R/W    | 0000_0000h  | 15.6.3/1053      |
| B_0E0C                     | Time stamp event register * (eTSEC1_1588_TMR_PEVENT)             | 32                 | w1c    | 0000_0000h  | 15.6.4/1054      |
| B_0E10                     | Timer event mask register * (eTSEC1_1588_TMR_PEMASK)             | 32                 | R/W    | 0000_0000h  | 15.6.5/1055      |
| B_0E14                     | Time stamp status register * (eTSEC1_1588_TMR_STAT)              | 32                 | R/W    | 0000_0000h  | 15.6.6/1056      |
| B_0E18                     | Timer counter high register * (eTSEC1_1588_TMR_CNT_H)            | 32                 | R/W    | 0000_0000h  | 15.6.7/1057      |
| B_0E1C                     | Timer counter low register * (eTSEC1_1588_TMR_CNT_L)             | 32                 | R/W    | 0000_0000h  | 15.6.8/1058      |
| B_0E20                     | Timer drift compensation addend register * (eTSEC1_1588_TMR_ADD) | 32                 | R/W    | 0000_0000h  | 15.6.9/1059      |

## eTSEC1 memory map (continued)

| Offset address (hex) | Register name                                                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|----------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| B_0E24               | Timer accumulator register * (eTSEC1_1588_TMR_ACC)                         | 32                 | R      | 0000_0000h  | 15.6.10/<br>1060 |
| B_0E28               | Timer prescale * (eTSEC1_1588_TMR_PRSC)                                    | 32                 | R/W    | 0000_0002h  | 15.6.11/<br>1060 |
| B_0E30               | Timer offset high * (eTSEC1_1588_TMROFF_H)                                 | 32                 | R/W    | 0000_0000h  | 15.6.12/<br>1061 |
| B_0E34               | Timer offset low * (eTSEC1_1588_TMROFF_L)                                  | 32                 | R/W    | 0000_0000h  | 15.6.13/<br>1061 |
| B_0E40               | Timer alarm n high register * (eTSEC1_1588_TMR_ALARM1_H)                   | 32                 | R/W    | FFFF_FFFFh  | 15.6.14/<br>1062 |
| B_0E44               | Timer alarm n low register * (eTSEC1_1588_TMR_ALARM1_L)                    | 32                 | R/W    | FFFF_FFFFh  | 15.6.15/<br>1063 |
| B_0E48               | Timer alarm n high register * (eTSEC1_1588_TMR_ALARM2_H)                   | 32                 | R/W    | FFFF_FFFFh  | 15.6.14/<br>1062 |
| B_0E4C               | Timer alarm n low register * (eTSEC1_1588_TMR_ALARM2_L)                    | 32                 | R/W    | FFFF_FFFFh  | 15.6.15/<br>1063 |
| B_0E80               | Timer fixed period interval n * (eTSEC1_1588_TMR_FIPER1)                   | 32                 | R/W    | FFFF_FFFFh  | 15.6.16/<br>1063 |
| B_0E84               | Timer fixed period interval n * (eTSEC1_1588_TMR_FIPER2)                   | 32                 | R/W    | FFFF_FFFFh  | 15.6.16/<br>1063 |
| B_0EA0               | Time stamp of general purpose external trigger * (eTSEC1_1588_TMR_ETTS1_H) | 32                 | R      | 0000_0000h  | 15.6.17/<br>1065 |
| B_0EA4               | Time stamp of general purpose external trigger * (eTSEC1_1588_TMR_ETTS1_L) | 32                 | R      | 0000_0000h  | 15.6.18/<br>1065 |
| B_0EA8               | Time stamp of general purpose external trigger * (eTSEC1_1588_TMR_ETTS2_H) | 32                 | R      | 0000_0000h  | 15.6.17/<br>1065 |
| B_0EAC               | Time stamp of general purpose external trigger * (eTSEC1_1588_TMR_ETTS2_L) | 32                 | R      | 0000_0000h  | 15.6.18/<br>1065 |

# 15.6.1 Timer control register \* (eTSEC1x\_TMR\_CTRL)

The timer control register is used to reset, configure, and initialize the eTSEC precision timer clock. The control of all timer function is performed by programming eTSEC1. The register in eTSEC1 is shared for all eTSECs.





## eTSEC1x\_TMR\_CTRL field descriptions

| Field               | Description                                                   |
|---------------------|---------------------------------------------------------------|
| 0<br>ALM1P          | Alarm1 output polarity                                        |
|                     | 0 Active high output                                          |
|                     | 1 Active low output                                           |
| 1<br>ALM2P          | Alarm2 output polarity                                        |
|                     | 0 Active high output                                          |
|                     | 1 Active low output                                           |
| 2                   | This field is reserved.                                       |
| -                   | Reserved                                                      |
| 3<br>FS             | FIPER start indication                                        |
|                     | 0 Fiper is enabled through timer enable                       |
|                     | 1 Fiper is enabled through timer enable and alarm indication. |
| 4<br>PP1L           | Fiper1 pulse loopback mode enabled.                           |
|                     | 0 Trigger1 input is based upon normal external trigger input. |
|                     | 1 Fiper1 pulse is looped back into Trigger1 input.            |
| 5<br>PP2L           | Fiper2 pulse loopback mode enabled.                           |
|                     | 0 Trigger2 input is based upon normal external trigger input. |
|                     | 1 Fiper2 pulse is looped back into Trigger2 input.            |
| 6–15<br>TCLK_PERIOD | 1588 timer reference clock period                             |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eTSEC1x\_TMR\_CTRL field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | The timer clock counter will increment by TCLK_PERIOD every time the accumulator register overflows. This clock period must be larger than the clock period of the timer reference clock. For applications where user does not want the clock period to be added, they can program this field to 1 to count the clock ticks. This field defaulted to 1 to count overflow ticks. |
| 16          | Record Tx Time-Stamp to PAL Enable.                                                                                                                                                                                                                                                                                                                                             |
| RTPE        | When set, and FCB[PTP] is set, the 8-byte time-stamp for the packet is written to the PAL located in external memory location at an offset of 16 bytes from the start of the Data Buffer Pointer of the first TxBD For guidelines on using the RTPE bit, refer to Time stamp insertion on transmit packets.                                                                     |
| 17          | FIPER Realignment Disable                                                                                                                                                                                                                                                                                                                                                       |
| FRD         | 0 Fiper Realignment is enabled.                                                                                                                                                                                                                                                                                                                                                 |
|             | 1 Fiper Realignment is disabled.                                                                                                                                                                                                                                                                                                                                                |
| 18–19<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                |
| 20<br>ESFDP | External Tx/Rx SFD Polarity. Note, when this bit is updated after timer is enabled, then afterwards the use would need to monitor TMR_STAT[RCD] till it is set, wait 6 timer clock cycles, and then clear TMR_TEVENT register.                                                                                                                                                  |
|             | 0 Time stamp on rising edge of external SFD indication.                                                                                                                                                                                                                                                                                                                         |
|             | 1 Time stamp on falling edge of external SFD indication.                                                                                                                                                                                                                                                                                                                        |
| 21<br>ESFDE | External Tx/Rx SFD Enable. Note, when this bit is updated after timer is enabled, then afterwards the user would need to monitor TMR_STAT[RCD] till it is set, wait 6 timer clock cycles, and then clear TMR_TEVENT register.                                                                                                                                                   |
|             | 0 Time stamp PTP TX frame based on MAC's SFD indication.                                                                                                                                                                                                                                                                                                                        |
|             | 1 Time stamp PTP TX frame based on external SFD indication from PHY.                                                                                                                                                                                                                                                                                                            |
| 22          | External trigger 2 edge polarity                                                                                                                                                                                                                                                                                                                                                |
| ETEP2       | 0 Time stamp on the rising edge of the external trigger                                                                                                                                                                                                                                                                                                                         |
|             | 1 Time stamp on the falling edge of the external trigger                                                                                                                                                                                                                                                                                                                        |
| 23<br>ETEP1 | External trigger 1 edge polarity                                                                                                                                                                                                                                                                                                                                                |
|             | 0 Time stamp on the rising edge of the external trigger                                                                                                                                                                                                                                                                                                                         |
| 0.4         | 1 Time stamp on the falling edge of the external trigger                                                                                                                                                                                                                                                                                                                        |
| 24<br>COPH  | Generated clock (TSEC_1588_CLK_OUT ) output phase.                                                                                                                                                                                                                                                                                                                              |
|             | 0 Non-inverted divided clock is output                                                                                                                                                                                                                                                                                                                                          |
|             | 1 Inverted divided clock is output                                                                                                                                                                                                                                                                                                                                              |
| 25<br>CIPH  | Oscillator input clock phase                                                                                                                                                                                                                                                                                                                                                    |
| OIFF        | 0 Non-inverted timer input clock                                                                                                                                                                                                                                                                                                                                                |
|             | 1 Inverted timer input clock inverted frequency tuned timer input clock. Note that this setting is reserved if CKSEL = 01.                                                                                                                                                                                                                                                      |
| 26          | Timer soft reset                                                                                                                                                                                                                                                                                                                                                                |
| TMSR        | When enabled, it resets all the timer registers and state machines. User programmable registers are not reset by the soft reset(e.g. TMR_CTRL, TMR_TEMASK, TMR_PEMASK, TMR_ADD, TMR_PRSC, TMROFF_H/L, TMR_ALARMn, and TMR_FIPERn.                                                                                                                                               |
|             | NOTE: Prior to initiating timer reset (setting TMSR), must gracefully stop receiver (See MACCFG1[RX_EN] description).                                                                                                                                                                                                                                                           |

# eTSEC1x\_TMR\_CTRL field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|           | Normal operation     Place optive times in react except central and centils registers.                                                                                                                                                                                                                                                                                                                |  |  |
|           | 1 Place entire timer in reset except control and config registers                                                                                                                                                                                                                                                                                                                                     |  |  |
| 27        | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 28<br>BYP | Bypass drift compensated clock                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|           | 0 64-bit clock counter is incremented on the accumulator overflow                                                                                                                                                                                                                                                                                                                                     |  |  |
|           | 1 64-bit clock counter is directly driven from the external oscillator ignoring accumulator overflow                                                                                                                                                                                                                                                                                                  |  |  |
| 29        | 1588 timer enable                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| TE        | If not enabled, all the timer registers and state machines are disabled.                                                                                                                                                                                                                                                                                                                              |  |  |
|           | 0 Timer not enabled                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|           | 1 Timer enabled and resume normal operation                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 30–31     | 1588 Timer reference clock source select.                                                                                                                                                                                                                                                                                                                                                             |  |  |
| CKSEL     | Note that the 1588 reference clock must be no slower than 1/7 the Rx_clk frequency.                                                                                                                                                                                                                                                                                                                   |  |  |
|           | The default clock select is eTSEC system clock, which is always active when eTSEC is enabled. The user must ensure the corresponding clock source is active before changing the 1588 refclk selection to an external reference, RTC, or Tx clock. Selecting an inactive 1588 reference clock may cause boundedly undefined behavior in the Ethernet controller and on accesses to the 1588 registers. |  |  |
|           | 00 External high precision timer reference clock (TSEC_1588_CLK_IN )                                                                                                                                                                                                                                                                                                                                  |  |  |
|           | 01 eTSEC system clock                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|           | 10 eTSEC1 transmit clock                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|           | 11 RTC clock input.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

## 15.6.2 Time stamp event register \* (eTSEC1x\_TMR\_TEVENT)

The eTSEC precision timer implementation can generate additional interrupts that are independent of the frame based events that controlled via IEVENTG g. The timer interrupts are not affected by any interrupt coalescing that may be specified in TXIC/RXIC. Software may poll this register at any time to check for pending interrupts. If an event occurs and its corresponding enable bit is set in the event mask register (TEMASK), the event also causes a hardware interrupt at the PIC. A bit in the timer event register is cleared by writing a 1 to that bit position.





eTSEC1x TMR TEVENT field descriptions

| Description                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------|
| This field is reserved. Reserved                                                                                        |
| External trigger 2 time stamp sampled  0 External trigger time stamp not sampled  1 External trigger time stamp sampled |
| External trigger 1 time stamp sampled  0 External trigger time stamp not sampled  1 External trigger time stamp sampled |
| This field is reserved. Reserved                                                                                        |
| Current time equaled alarm time register 2  0 Alarm time has not been reached 1 Alarm time has been reached             |
|                                                                                                                         |

## eTSEC1x\_TMR\_TEVENT field descriptions (continued)

| Field      | Description                                                                  |
|------------|------------------------------------------------------------------------------|
| 15<br>ALM1 | Current time equaled alarm time register 1                                   |
|            | 0 Alarm time has not been reached                                            |
|            | 1 Alarm time has been reached                                                |
| 16–23<br>- | This field is reserved. Reserved                                             |
| 24<br>PP1  | Indicates that a periodic pulse has been generated based on FIPER1 register. |
|            | 0 Periodic pulse not generated                                               |
|            | 1 Periodic pulse generated                                                   |
| 25<br>PP2  | Indicates that a periodic pulse has been generated based on FIPER2 register. |
|            | 0 Periodic pulse not generated                                               |
|            | 1 Periodic pulse generated                                                   |
| 26–31<br>- | This field is reserved. Reserved                                             |

# 15.6.3 Timer event mask register \* (eTSEC1x\_TMR\_TEMASK)

Timer event mask register. The event mask register provides control over which possible interrupt events in the TMR\_TEVENT register are permitted to participate in generating hardware interrupts to the PIC. All implemented bits in this register are R/W and cleared upon a hardware reset.





### eTSEC1x\_TMR\_TEMASK field descriptions

| Field        | Description                                       |
|--------------|---------------------------------------------------|
| 0–5<br>-     | This field is reserved. Reserved                  |
| 6<br>ETS2EN  | External trigger 2 time stamp sample event enable |
| 7<br>ETS1EN  | External trigger 1 time stamp sample event enable |
| 8–13<br>-    | This field is reserved. Reserved                  |
| 14<br>ALM2EN | Timer ALM1 event enable                           |
| 15<br>ALM1EN | Timer ALM2 event enable                           |
| 16–23<br>-   | This field is reserved. Reserved                  |
| 24<br>PP1EN  | Periodic pulse event 1 enable                     |
| 25<br>PP2EN  | Periodic pulse event 2 enable                     |
| 26–31<br>-   | This field is reserved. Reserved                  |

# 15.6.4 Time stamp event register \* (eTSEC1x\_TMR\_PEVENT)

The eTSEC precision timer logic can generate interrupts upon the capture of a time stamp due to either transmission or reception of a frame. If an event occurs and its corresponding enable bit is set in the event mask register (PEMASK), the event also causes a hardware interrupt at the PIC. A bit in the timer event register is cleared by writing a 1 to that bit position.





## eTSEC1x\_TMR\_PEVENT field descriptions

| Field      | Description                                                                                     |
|------------|-------------------------------------------------------------------------------------------------|
| 0–21       | This field is reserved.                                                                         |
| -          | Reserved                                                                                        |
| 22<br>TXP2 | Indicates that a PTP frame has been transmitted and its time stamp is stored in TXTS2 register. |
|            | 0 PTP packet not transmitted                                                                    |
|            | 1 PTP packet has been transmitted                                                               |
| 23<br>TXP1 | Indicates that a PTP frame has been transmitted and its time stamp is stored in TXTS1 register. |
|            | 0 PTP packet not transmitted                                                                    |
|            | 1 PTP packet has been transmitted                                                               |
| 24–30<br>- | This field is reserved. Reserved                                                                |
| 31<br>RXP  | Indicates that a PTP frame has been received                                                    |
|            | 0 PTP packet not received                                                                       |
|            | 1 PTP packet has been received                                                                  |

# 15.6.5 Timer event mask register \* (eTSEC1x\_TMR\_PEMASK)

Timer event mask register. The event mask register provides control over which possible interrupt events in the TMR\_PEVENT register are permitted to participate in generating hardware interrupts to the PIC. All implemented bits in this register are R/W and cleared upon a hardware reset.





#### eTSEC1x\_TMR\_PEMASK field descriptions

| Field        | Description                        |
|--------------|------------------------------------|
| 0–21<br>-    | This field is reserved. Reserved   |
| 22<br>TXP2EN | Transmit PTP packet event 2 enable |
| 23<br>TXP1EN | Transmit PTP packet event 1 enable |
| 24–30        | This field is reserved. Reserved   |
| 31<br>RXPEN  | Receive PTP packet event enable    |

# 15.6.6 Time stamp status register \* (eTSEC1x\_TMR\_STAT)

The STAT\_VEC register field of TMR\_STAT requires the eTSEC filer to be enabled (via RCTRL[FILREN]). When eTSEC generates an interrupt based on the time stamp event for a received packet, the queue ID which the incoming packet will be sent to is captured in this register. The STAT\_VEC register field update is synchronized with the RXF interrupt of the corresponding received packet. Writing 1 to any STAT\_VEC field bit clears it.

Address: B\_0000h base + E14h offset = B\_0E14h



eTSEC1x\_TMR\_STAT field descriptions

| Field | Description                                                                                                                                                                                                                                     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Timer Reference Clock Detected                                                                                                                                                                                                                  |
| RCD   | The selected timer clock, TMR_CTRL[CKSEL], is sensed as being active. When it is not active, register read/write accesses to timer clock domain registers will not be allowed. Refer to Table 15-1074 and Table 15-1075. It is a read-only bit. |

### eTSEC1x\_TMR\_STAT field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <ul> <li>Selected timer reference clock is not active. User cannot access timer clock domain registers. Reads return 0; writes are ignored.</li> <li>Selected timer reference clock is active.</li> </ul>                                                                                  |
| 1–25<br>-         | This field is reserved. Reserved                                                                                                                                                                                                                                                           |
| 26–31<br>STAT_VEC | Timer general purpose status vector. It will store the 6-bit queue number generated by the filer. User to decode this status vector. For example, user can encode received PTP packet message types (Sync, Delay_req, Follow_up, Delay_resp, Management) in the filer virtual queue field. |

# 15.6.7 Timer counter high register \* (eTSEC1x\_TMR\_CNT\_H)

The timer register (TMR\_CNT\_H) represents accurate time in terms clock ticks or in nanoseconds. Writes to this register will override the previous time. The register in eTSEC1 is shared for all eTSECs. These are read/write registers.

Address: B\_0000h base + E18h offset = B\_0E18h



#### eTSEC1x\_TMR\_CNT\_H field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>TMR_CNT_H | Value of the current time counter (upper half). Current time is calculated by adding TMROFF_H/L with the TMR_CNT_H/L counter. This register can be written through the register writes. Writes to the TMR_CNT_L register copies the written value into the shadow TMR_CNT_L register. Writes to the TMR_CNT_H register copies the values written into the shadow TMR_CNT_H register. Contents of the shadow registers are copied into the TMR_CNT_L and TMR_CNT_H registers following a write into the TMR_CNT_H register. Writes to these registers have precedence over the timer increment. The user must write to TMR_CNT_L register first. |
|                   | Reads from the TMR_CNT_L register copies the entire 64-bit clock time of the read enable into the TMR_CNT_H/L shadow registers. Read instruction from the TMR_CNT_H register reads the value stored in the TMR_CNT_H shadow register. The user must read the TMR_CNT_L register first to get correct 64-bit TMR_CNT_H/L counter values.                                                                                                                                                                                                                                                                                                         |

## 15.6.8 Timer counter low register \* (eTSEC1x\_TMR\_CNT\_L)

The timer register (TMR\_CNT\_L) represents accurate time in terms clock ticks or in nanoseconds. Writes to this registers will override the previous time. The register in eTSEC1 is shared for all eTSECs. These are read/write registers.

Address: B\_0000h base + E1Ch offset = B\_0E1Ch



### eTSEC1x\_TMR\_CNT\_L field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>TMR_CNT_L | Value of the current time counter (lower half). Current time is calculated by adding TMROFF_H/L with the TMR_CNT_H/L counter. This register can be written through the register writes. Writes to the TMR_CNT_L register copies the written value into the shadow TMR_CNT_L register. Writes to the TMR_CNT_H register copies the values written into the shadow TMR_CNT_H register. Contents of the shadow registers are copied into the TMR_CNT_L and TMR_CNT_H registers following a write into the TMR_CNT_H register. Writes to these registers have precedence over the timer increment. The user must write to TMR_CNT_L register first. |
|                   | Reads from the TMR_CNT_L register copies the entire 64-bit clock time of the read enable into the TMR_CNT_H/L shadow registers. Read instruction from the TMR_CNT_H register reads the value stored in the TMR_CNT_H shadow register. The user must read the TMR_CNT_L register first to get correct 64-bit TMR_CNT_H/L counter values.                                                                                                                                                                                                                                                                                                         |

# 15.6.9 Timer drift compensation addend register \* (eTSEC1x\_TMR\_ADD)

The timer drift compensation addend register (TMR\_ADD) is used to hold the timer frequency compensation value (FreqCompensationValue). The nominal frequency of the clock counter is determined by the FreqDivRatio and the clock frequency (FreqClock). This register is programmed with 2 <sup>32</sup> ÷ FreqDivRatio. The frequency division ratio (FreqDivRatio) is the ratio between the frequency of the oscillator (TimerOsc) and the desired clock frequency (NominalFreq). FreqDivRatio is a design constant chosen to be greater than 1.0001. The ADDEND value is added to the 32-bit accumulator register at every rising edge of the oscillator clock (TimerOsc). The clock counter is incremented at every carry pulse of the accumulator. Only one TMR\_ADD register is required for the entire group of eTSECs.





#### eTSEC1x TMR ADD field descriptions

| Field  | Description                                                             |
|--------|-------------------------------------------------------------------------|
| 0–31   | Timer drift compensation addend register value                          |
| ADDEND | It is programmed with a value of 2 $^{32}$ ÷ FreqDivRatio. For example: |
|        | TimerOsc = 50 MHz                                                       |
|        | NominalFreq = 40 MHz                                                    |
|        | FreqDivRatio = 1.25                                                     |
|        | ADDEND = $ceil(2^{32} \div 1.25) = 0xCCCC\_CCCD$                        |

## 15.6.10 Timer accumulator register \* (eTSEC1x\_TMR\_ACC)

The timer accumulator register accumulates the value of the addend register into it. An overflow pulse of the accumulator is used to increment the timer clock by TMR\_CTRL[TCLK\_PERIOD]. This register is read only in normal operation. The register in eTSEC1 is shared for all eTSECs.





### eTSEC1x\_TMR\_ACC field descriptions

| Field           | Description                       |
|-----------------|-----------------------------------|
| 0-31<br>TMR_ACC | 32-bit timer accumulator register |

# 15.6.11 Timer prescale \* (eTSEC1x\_TMR\_PRSC)

The timer generated output clock prescale register is used to adjust the output clock frequency that is put onto the 1588 clock output signal. The register in eTSEC1 is shared for all eTSECs.

Address: B\_0000h base + E28h offset = B\_0E28h



#### eTSEC1x\_TMR\_PRSC field descriptions

| Field             | Description                                                                                                                                                                                                          |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-         | This field is reserved. Reserved                                                                                                                                                                                     |
| 16-31<br>PRSC_OCK | Output clock division/prescale factor  The output clock is generated by dividing the timer input clock by this number. Programmed value in this field must be greater than 1. Any value less than 1 is treated as 2. |

## 15.6.12 Timer offset high \* (eTSEC1x\_TMROFF\_H)

The timer offset registers are used to provide current time by adding their value to the clock counter.

#### NOTE

All TMROFF\_H registers in a device should be set to the same value, and all TMROFF\_L registers in a device should be set to the same value. Otherwise, the precision time protocol may not work.





### eTSEC1x\_TMROFF\_H field descriptions

| Field    | Description                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------|
|          | Offset value of the clock counter (upper half)                                                      |
| TMROFF_H | The current time in is calculated by adding TMROFF_H with the timer's counter TMR_CNT_H/L register. |

# 15.6.13 Timer offset low \* (eTSEC1x\_TMROFF\_L)

The timer offset registers are used to provide current time by adding their value to the clock counter.

#### NOTE

All TMROFF\_H registers in a device should be set to the same value, and all TMROFF\_L registers in a device should be set to the same value. Otherwise, the precision time protocol may not work.

#### Address: B\_0000h base + E34h offset = B\_0E34h



### eTSEC1x\_TMROFF\_L field descriptions

| Field    | Description                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------|
|          | Offset value of the clock counter (lower half)                                                      |
| TMROFF_L | The current time in is calculated by adding TMROFF_L with the timer's counter TMR_CNT_H/L register. |

# 15.6.14 Timer alarm n high register \* (eTSEC1x\_TMR\_ALARMn\_H)

The alarm time comparator registers (TMR\_ALARM n\_H) hold alarm time for comparison with the current time counter. There are two sets of these registers for eTSEC1, which are shared among all eTSECs.



### eTSEC1x\_TMR\_ALARMn\_H field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31    | Alarm time comparator register (upper half)                                                                                                                                                                                                                                                                                                                                              |
| ALARM_H | The corresponding alarm event in TMR_TEVENT is set when the current time counter becomes equal to or greater than the alarm time compare value in TMR_ALARM $n$ _L/H. Writing the TMR_ALARM $n$ _L register deactivates the alarm event after it has fired. Writing the TMR_ALARM $n$ _L followed by the TMR_ALARM $n$ _H register rearms the alarm function with the new compare value. |
|         | The value programmed in this register must be an integer multiple of TMR_CTRL[TCLK_PERIOD] in order to get correct result. This register is reset to all ones to avoid false alarm after reset.                                                                                                                                                                                          |
|         | In FS mode the alarm trigger is used as an indication to the fiper start down counting. Only alarm 1 supports this mode. In FS mode, alarm polarity bit should be configured to 0 (rising edge).                                                                                                                                                                                         |

## 15.6.15 Timer alarm n low register \* (eTSEC1x\_TMR\_ALARMn\_L)

The alarm time comparator registers (TMR\_ALARM n\_L) hold alarm time for comparison with the current time counter. There are two sets of these registers for eTSEC1, which are shared among all eTSECs.



### eTSEC1x\_TMR\_ALARMn\_L field descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31    | Alarm time comparator register (lower half)                                                                                                                                                                                                                                                                                                                                              |
| ALARM_L | The corresponding alarm event in TMR_TEVENT is set when the current time counter becomes equal to or greater than the alarm time compare value in TMR_ALARM $n$ _L/H. Writing the TMR_ALARM $n$ _L register deactivates the alarm event after it has fired. Writing the TMR_ALARM $n$ _L followed by the TMR_ALARM $n$ _H register rearms the alarm function with the new compare value. |
|         | The value programmed in this register must be an integer multiple of TMR_CTRL[TCLK_PERIOD] in order to get correct result. This register is reset to all ones to avoid false alarm after reset.                                                                                                                                                                                          |
|         | In FS mode the alarm trigger is used as an indication to the fiper start down counting. Only alarm 1 supports this mode. In FS mode, alarm polarity bit should be configured to 0 (rising edge).                                                                                                                                                                                         |

# 15.6.16 Timer fixed period interval n \* (eTSEC1x\_TMR\_FIPERn)

The timer fixed interval period pulse generator register is used to generate periodic pulses. This register is reset with 0xFFFF\_FFFF to prevent any false pulse upon initialization. The down count register loads the value programmed in the fixed period interval (FIPER). FIPER register must be programmed before the timer is enabled. At every tick of the timer accumulator overflow, the counter decrements by the value of TMR\_CTRL[TCLK\_PERIOD]. It generates a pulse when the down counter value reaches zero. It reloads the down counter in the cycle following a pulse.

To use the TMR\_FIPER1 register to generate a 1 PPS event, the following setup should be used:

- 1. Program TMR\_FIPER1 to a value that will generate a pulse every second.
- 2. Program TMR\_ALARM1 to the correct time for the first PPS event.
- 3. Enable the timer.

#### eTSEC IEEE 1588 PTP memory map/register definition

The eTSEC then waits for TMR\_ALARM1 to expire before enabling the count down of TMR\_FIPER1. The end result is that TMR\_FIPER1 pulses every second after the original timer ALARM1 expired.

#### NOTE

In cases where the PPS signals are required to be phased aligned to the prescale output clock, the alarm value should be configured to **1 clock period less** than the wanted value.

In order to keep tracking the prescale output clock, each time before enabling the FIPER, the user must reset the FIPER by writing a new value to the register. The ratio between the prescale register value and the FIPER value should be devisable by the clk period, as follows:

FIPER\_VALUE = (prescale\_value x tclk\_per x N) - tclk\_per

For example, if prescale = 9 and clock period = 10, the FIPER can obtain the following values: 80, 170, 260 ......

The two registers in eTSEC1 are shared for all eTSECs.





#### eTSEC1x\_TMR\_FIPERn field descriptions

| Field | Description                                                                                                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Fixed interval pulse period register. This field must be programmed to an integer multiple of TMR_CTRL[TCLK_PERIOD] value to ensure a period pulse being generated correctly. |

# 15.6.17 Time stamp of general purpose external trigger \* (eTSEC1x\_TMR\_ETTSn\_H)

The general purpose external trigger stamp registers (TMR\_ETTS n \_H/L) hold time at the programmable edge of the external trigger. The registers in eTSEC1 are shared for all eTSECs. These registers are read only in normal operation.



### eTSEC1x\_TMR\_ETTSn\_H field descriptions

| Field | Description                                                                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Time stamp field at the programmable edge of the external trigger (upper half). For time-stamping of back-2-back trigger events, the trigger edges can be no closer than 5 timer clocks apart. |

# 15.6.18 Time stamp of general purpose external trigger \* (eTSEC1x\_TMR\_ETTSn\_L)

The general purpose external trigger stamp registers (TMR\_ETTS n\_H/L) hold time at the programmable edge of the external trigger. The registers in eTSEC1 are shared for all eTSECs. These registers are read only in normal operation.



## eTSEC1x\_TMR\_ETTSn\_L field descriptions

|   | Field  | Description                                                                                          |
|---|--------|------------------------------------------------------------------------------------------------------|
| Γ | 0–31   | Time stamp field at the programmable edge of the external trigger (lower half). For time-stamping of |
|   | ETTS_L | back-2-back trigger events, the trigger edges can be no closer than 5 timer clocks apart.            |

# 15.7 MDIO memory map/register definition

The following table lists the offset, name, and a cross-reference to the complete description of each eTSEC MDIO register.

eTSEC\_MDIO memory map

| Offset<br>address<br>(hex) | Register name                                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_4010                     | MDIO Interrupt event register (eTSEC1_MDIO_IEVENTM)         | 32                 | w1c    | 0000_0000h  | 15.7.1/1067      |
| 2_4014                     | MDIO Interrupt mask register (eTSEC1_MDIO_IMASKM)           | 32                 | R/W    | 0000_0000h  | 15.7.2/1069      |
| 2_401C                     | MDIO Error mapping register (eTSEC1_MDIO_EMAPM)             | 32                 | R/W    | 0000_0000h  | 15.7.3/1070      |
| 2_4520                     | MII management configuration register (eTSEC1_MDIO_MIIMCFG) | 32                 | R/W    | 0000_0007h  | 15.7.4/1070      |
| 2_4524                     | MII management command register (eTSEC1_MDIO_MIIMCOM)       | 32                 | R/W    | 0000_0000h  | 15.7.5/1072      |
| 2_4528                     | MII management address register (eTSEC1_MDIO_MIIMADD)       | 32                 | R/W    | 0000_0000h  | 15.7.6/1073      |
| 2_452C                     | MII management control register (eTSEC1_MDIO_MIIMCON)       | 32                 | R/W    | 0000_0000h  | 15.7.7/1074      |
| 2_4530                     | MII management status register (eTSEC1_MDIO_MIIMSTAT)       | 32                 | R      | 0000_0000h  | 15.7.8/1074      |
| 2_4534                     | MII management indicator register (eTSEC1_MDIO_MIIMIND)     | 32                 | R      | 0000_0000h  | 15.7.9/1075      |
| 2_5010                     | MDIO Interrupt event register (eTSEC2_MDIO_IEVENTM)         | 32                 | w1c    | 0000_0000h  | 15.7.1/1067      |
| 2_5014                     | MDIO Interrupt mask register (eTSEC2_MDIO_IMASKM)           | 32                 | R/W    | 0000_0000h  | 15.7.2/1069      |
| 2_501C                     | MDIO Error mapping register (eTSEC2_MDIO_EMAPM)             | 32                 | R/W    | 0000_0000h  | 15.7.3/1070      |
| 2_5520                     | MII management configuration register (eTSEC2_MDIO_MIIMCFG) | 32                 | R/W    | 0000_0007h  | 15.7.4/1070      |
| 2_5524                     | MII management command register (eTSEC2_MDIO_MIIMCOM)       | 32                 | R/W    | 0000_0000h  | 15.7.5/1072      |
| 2_5528                     | MII management address register (eTSEC2_MDIO_MIIMADD)       | 32                 | R/W    | 0000_0000h  | 15.7.6/1073      |
| 2_552C                     | MII management control register (eTSEC2_MDIO_MIIMCON)       | 32                 | R/W    | 0000_0000h  | 15.7.7/1074      |
| 2_5530                     | MII management status register (eTSEC2_MDIO_MIIMSTAT)       | 32                 | R      | 0000_0000h  | 15.7.8/1074      |
| 2_5534                     | MII management indicator register (eTSEC2_MDIO_MIIMIND)     | 32                 | R      | 0000_0000h  | 15.7.9/1075      |
| 2_6010                     | MDIO Interrupt event register (eTSEC3_MDIO_IEVENTM)         | 32                 | w1c    | 0000_0000h  | 15.7.1/1067      |
| 2_6014                     | MDIO Interrupt mask register (eTSEC3_MDIO_IMASKM)           | 32                 | R/W    | 0000_0000h  | 15.7.2/1069      |
| 2_601C                     | MDIO Error mapping register (eTSEC3_MDIO_EMAPM)             | 32                 | R/W    | 0000_0000h  | 15.7.3/1070      |

### eTSEC\_MDIO memory map (continued)

| Offset address (hex) | Register name                                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_6520               | MII management configuration register (eTSEC3_MDIO_MIIMCFG) | 32                 | R/W    | 0000_0007h  | 15.7.4/1070      |
| 2_6524               | MII management command register (eTSEC3_MDIO_MIIMCOM)       | 32                 | R/W    | 0000_0000h  | 15.7.5/1072      |
| 2_6528               | MII management address register (eTSEC3_MDIO_MIIMADD)       | 32                 | R/W    | 0000_0000h  | 15.7.6/1073      |
| 2_652C               | MII management control register (eTSEC3_MDIO_MIIMCON)       | 32                 | R/W    | 0000_0000h  | 15.7.7/1074      |
| 2_6530               | MII management status register (eTSEC3_MDIO_MIIMSTAT)       | 32                 | R      | 0000_0000h  | 15.7.8/1074      |
| 2_6534               | MII management indicator register (eTSEC3_MDIO_MIIMIND)     | 32                 | R      | 0000_0000h  | 15.7.9/1075      |

# 15.7.1 MDIO Interrupt event register (eTSECx1\_MDIO\_IEVENTM)

MDIO interrupt events cause bits in the IEVENTM register to be set. This register is unique to the MDIO address space. Software may poll this register at any time to check for pending interrupts. If an event occurs, its corresponding enable bit is set in the MDIO interrupt mask register (IMASKM), the event also causes a hardware interrupt at the PIC . A bit in the interrupt event register is cleared by writing a 1 to that bit position . A write of 0 has no effect.

The MDIO events are considered operational diagnostic events to the PIC, and are mapped to an error interrupt via EMAPM.



#### MDIO memory map/register definition



## eTSECx1\_MDIO\_IEVENTM field descriptions

| Field      | Description                                                                                                                                                                                                                   |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–20<br>-  | This field is reserved. Reserved                                                                                                                                                                                              |
| 21<br>MMRD | <ul> <li>MII management read completion</li> <li>0 MII management read not issued or in process.</li> <li>1 MII management read completed that was initiated by a user through the MII Scan or Read cycle command.</li> </ul> |
| 22<br>MMWR | MII management write completion  0 MII management write not issued or in process.  1 MII management write completed that was initiated by a user write to the MIIMCON register.                                               |
| 23–31<br>- | This field is reserved. Reserved                                                                                                                                                                                              |

## 15.7.2 MDIO Interrupt mask register (eTSECx1\_MDIO\_IMASKM)

The MDIO interrupt mask register provides control over which possible interrupt events in the IEVENTM register are permitted to participate in generating hardware interrupts to the PIC. All implemented bits in this register are R/W and cleared upon a hardware reset. If the corresponding bits in both the IEVENTM and IMASKM registers are set, the PIC receives an error/diagnostic interrupts. The interrupt signal remains asserted until either the IEVENTM bit is cleared, either by writing a 1 to it or by writing a 0 to the corresponding IMASKM bit.



Field Description

0-20 This field is reserved.
Reserved

21 MII management read completion interrupt enable

MMRDEN

22 MII management write completion interrupt enable

23-31 This field is reserved.
Reserved

Reserved

## 15.7.3 MDIO Error mapping register (eTSECx1\_MDIO\_EMAPM)

The error mapping register allows the user to route MDIO events to a particular group error interrupt.

Address: Base address + 1Ch offset



### eTSECx1\_MDIO\_EMAPM field descriptions

| Field         | Description                                             |
|---------------|---------------------------------------------------------|
| 0–1<br>MMRDGP | MII management read completion interrupt group mapping  |
|               | 00 Map to group 0                                       |
|               | 01 Map to group 1                                       |
|               | 10 Reserved                                             |
|               | 11 Reserved                                             |
| 2–3<br>MMWRGP | MII management write completion interrupt group mapping |
|               | 00 Map to group 0                                       |
|               | 01 Map to group 1                                       |
|               | 10 Reserved                                             |
|               | 11 Reserved                                             |
| 4–31<br>-     | This field is reserved. Reserved                        |

# 15.7.4 MII management configuration register (eTSECx1\_MDIO\_MIIMCFG)

The MIIMCFG register is written by the user to configure all MII management operations. Note that MII management hardware is shared by all eTSECs. Thus, only through the MIIM registers of eTSEC1 can external PHYs be accessed and configured.

#### NOTE

When an eTSEC is configured to use TBI/RTBI, configuration of the TBI/RTBI (described in Ten-bit interface (TBI)) is done through the MIIM registers for that eTSEC. For example, if a

# TBI/RTBI interface is required on eTSEC2, then the MIIM registers starting at offset 0x2\_5520 are used to configure it.

## See MAC functionality for more details.



## eTSECx1\_MDIO\_MIIMCFG field descriptions

| Field            | Description                                                                                                                                              |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Reset_Mgmt  | Reset management . This bit is cleared by default.                                                                                                       |
|                  | <ul><li>Allow the MII MGMT to perform mgmt read/write cycles if requested through the host interface.</li><li>Reset the MII MGMT.</li></ul>              |
| 1–26<br>-        | This field is reserved. Reserved                                                                                                                         |
| 27<br>No_Pre     | Preamble suppress . This bit is cleared by default.                                                                                                      |
|                  | The MII MGMT performs Mgmt read/write cycles with 32 clocks of preamble.                                                                                 |
|                  | 1 The MII MGMT suppresses preamble generation and reduces the Mgmt cycle from 64 clocks to 32 clocks . This is in accordance with IEEE 802.3/22.2.4.4.2. |
| 28<br>-          | This field is reserved. Reserved                                                                                                                         |
| 29–31<br>MgmtClk | This field determines the clock frequency of the MII management clock (EC_MDC) . Its default value is 111.                                               |
|                  | NOTE: The eTSEC system clock is derived from (CCB Clock)/2.                                                                                              |
|                  | 000 1/4 of the eTSEC system clock divided by 8                                                                                                           |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eTSECx1\_MDIO\_MIIMCFG field descriptions (continued)

| Field | Description                                     |
|-------|-------------------------------------------------|
|       | 001 1/4 of the eTSEC system clock divided by 8  |
|       | 010 1/6 of the eTSEC system clock divided by 8  |
|       | 011 1/8 of the eTSEC system clock divided by 8  |
|       | 100 1/10 of the eTSEC system clock divided by 8 |
|       | 101 1/14 of the eTSEC system clock divided by 8 |
|       | 110 1/20 of the eTSEC system clock divided by 8 |
|       | 111 1/28 of the eTSEC system clock divided by 8 |

# 15.7.5 MII management command register (eTSECx1\_MDIO\_MIIMCOM)

The MIIMCOM register is written by the user.



## eTSECx1\_MDIO\_MIIMCOM field descriptions

| Field            | Description                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–29<br>-        | This field is reserved. Reserved                                                                                                                                               |
| 30<br>Scan_Cycle | Scan_Cycle. This bit is cleared by default.  O Normal operation.  The MII management continuously performs read cycles . This is useful for monitoring link fail, for example. |
| 31<br>Read_Cycle | Read_Cycle. This bit is cleared by default but is not self-clearing once set.                                                                                                  |

## eTSECx1\_MDIO\_MIIMCOM field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0 Normal operation.                                                                                                                                                                                                                                                                                                                                                                                |
|       | 1 The MII management performs a single read cycle upon the transition of this bit from 0 to 1 using the PHY address (at MIIMADD[PHY_Address]) and the register address (at MIIMADD[Register_Address]). The 0-to-1 transition of this bit also causes the MIIMIND[Busy] bit to be set . The read is complete when the MIIMIND[Busy] bit clears . Data is returned in register MIIMSTAT[PHY Status]. |

# 15.7.6 MII management address register (eTSECx1\_MDIO\_MIIMADD)

The MIIMADD register is written by the user. See MAC functionality for more details.





### eTSECx1\_MDIO\_MIIMADD field descriptions

| Field                         | Description                                                                                                                                                                                                                                                                |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–18<br>-                     | This field is reserved. Reserved                                                                                                                                                                                                                                           |
| 19–23<br>PHY_Address          | At most, 31 external PHYs can be addressed, because one of the 32 possible addresses this field can hold is reserved for the TBI (internal PHY). At reset, the TBI PHY address is 0. However, PHY Address also defaults to 0; thus, by default, mgmt cycles go to the TBI. |
|                               | The MII PHY can use address 0 if the TBI PHY address is set to a non-zero value. The TBI PHY address is set in the TBIPA register; see TBI PHY address register (eTSEC_TBIPA).                                                                                             |
|                               | Note that writing a non-zero value to TBIPA makes that value reserved in the MII interface.                                                                                                                                                                                |
| 24–26<br>-                    | This field is reserved. Reserved                                                                                                                                                                                                                                           |
| 27–31<br>Register_<br>Address | This field represents the 5-bit register address field of Mgmt cycles . Up to 32 registers can be accessed . Its default value is 0x00.                                                                                                                                    |

# 15.7.7 MII management control register (eTSECx1\_MDIO\_MIIMCON)

MIIMCON is written by the user. See MAC functionality for more details.





### eTSECx1\_MDIO\_MIIMCON field descriptions

| Field       | Description                                                                                                                                                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-   | This field is reserved. Reserved                                                                                                                                                                                         |
| PHY_Control | If written, an MII Mgmt write cycle is performed using this 16-bit data, the pre-configured PHY address (at MIIMADD[PHY_Address]) and the register address (at MIIMADD[Register_Address]) . Its default value is 0x0000. |

# 15.7.8 MII management status register (eTSECx1\_MDIO\_MIIMSTAT)

The MIIMSTAT register is read only by the user. See MAC functionality for more details.

Address: Base address + 530h offset



#### eTSECx1\_MDIO\_MIIMSTAT field descriptions

| Field               | Description                                                                                                     |
|---------------------|-----------------------------------------------------------------------------------------------------------------|
| 0–15<br>-           | This field is reserved. Reserved                                                                                |
| 16-31<br>PHY_Status | Following an MII Mgmt read cycle, the 16-bit data can be read from this location . Its default value is 0x0000. |

# 15.7.9 MII management indicator register (eTSECx1\_MDIO\_MIIMIND)

The MIIMIND register is read-only by the user. See MAC functionality for more details.



eTSECx1\_MDIO\_MIIMIND field descriptions

| Field     | Description                                                                   |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0–28      | his field is reserved.                                                        |  |  |  |  |  |  |
| -         | eserved                                                                       |  |  |  |  |  |  |
| 29        | Not valid.                                                                    |  |  |  |  |  |  |
| Not_Valid |                                                                               |  |  |  |  |  |  |
|           | 0 MII Mgmt read cycle has completed and the read data is valid.               |  |  |  |  |  |  |
|           | MII Mgmt read cycle has not completed and the read data is not yet valid.     |  |  |  |  |  |  |
| 30        | Scan in progress.                                                             |  |  |  |  |  |  |
| Scan      |                                                                               |  |  |  |  |  |  |
|           | A scan operation (continuous MII Mgmt read cycles) is not in progress.        |  |  |  |  |  |  |
|           | A scan operation (continuous MII Mgmt read cycles) is in progress.            |  |  |  |  |  |  |
| 31        | Busy.                                                                         |  |  |  |  |  |  |
| Busy      |                                                                               |  |  |  |  |  |  |
|           | 0 MII Mgmt block is not currently performing an MII Mgmt read or write cycle. |  |  |  |  |  |  |
|           | 1 MII Mgmt block is currently performing an MII Mgmt read or write cycle.     |  |  |  |  |  |  |

# 15.8 TBI memory map/register definition

This section describes the TBI MII registers. All of the TBI registers are 16 bits wide. The TBI registers are accessed at the offset of the TBI physical address. The eTSEC's TBI physical address is stored in the TBIPA register. Writing to the TBI registers is performed in a way similar to writing to an external PHY, using the MII management

#### TBI memory map/register definition

interface . Using TBIPA in place of the PHY address, in the MIIMADD[PHY Address] field, and setting the MIIMADD[Register Address] to the appropriate address offset that corresponds to the register that one wants to read or write the user can read (set MIIMCOM[read cycle]) or write (writing to MIIMCON[PHY control]) to the TBI block . Refer to the TBI physical address register in eTSEC memory map/register definition , and the TBI MII register set in the table below. Notice that jitter diagnostics and TBI control are not IEEE 802.3 required registers and are only used for test and control of the eTSEC TBI block. The TBI's TBI control register (TBI) is for configuring the eTSEC ten-bit interface block. However, because this TBI block has an MII management interface (just like any other PHY), it has an IEEE 802.3 register called the control register (CR).

TBI MII Register Set memory map

| Absolute<br>address<br>(hex) | Register name                                                                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 0                            | Control (TBI_MII_Register_Set_CR)                                                                         | 16                 | R/W    | 1140h       | 15.8.1/1077      |
| 1                            | Status (TBI_MII_Register_Set_SR)                                                                          | 16                 | R      | 0149h       | 15.8.2/1078      |
| 4                            | AN Advertisement Register for 1000Base-X auto-negotiation (TBI_MII_Register_Set_ANA)                      | 16                 | R/W    | 0000h       | 15.8.3/1079      |
| 4                            | AN Advertisement Register for SGMII auto-negotiation (TBI_MII_Register_Set_ANA_SGMII)                     | 16                 | R/W    | 0000h       | 15.8.4/1081      |
| 5                            | AN Link Partner Base Page Ability Register for 1000Base-X auto-negotiation (TBI_MII_Register_Set_ANLPBPA) | 16                 | R      | 0000h       | 15.8.5/1082      |
| 5                            | AN Link Partner Base Page Ability Register for SGMII autonegotiation (TBI_MII_Register_Set_ANLPBPA_SGMII) | 16                 | R      | 0000h       | 15.8.6/1083      |
| 6                            | AN expansion (TBI_MII_Register_Set_ANEX)                                                                  | 16                 | R      | 0000h       | 15.8.7/1084      |
| 7                            | AN next page transmit (TBI_MII_Register_Set_ANNPT)                                                        | 16                 | R/W    | 0000h       | 15.8.8/1085      |
| 8                            | AN link partner ability next page (TBI_MII_Register_Set_ANLPANP)                                          | 16                 | R      | 0000h       | 15.8.9/1086      |
| F                            | Extended status (TBI_MII_Register_Set_EXST)                                                               | 16                 | R      | A000h       | 15.8.10/<br>1087 |
| 10                           | Jitter diagnostics (TBI_MII_Register_Set_JD)                                                              | 16                 | R/W    | 0000h       | 15.8.11/<br>1088 |
| 11                           | TBI control (TBI_MII_Register_Set_TBICON)                                                                 | 16                 | R/W    | 0010h       | 15.8.12/<br>1089 |

# 15.8.1 Control (TBI\_MII\_Register\_Set\_CR)

Address: 0h



## TBI\_MII\_Register\_Set\_CR field descriptions

| Field                                      | Description                                                                                                                                                                                                                                                                          |                         |                   |  |  |  |  |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------|--|--|--|--|
| 0<br>PHY_Reset                             | PHY reset. This bit is cleared by default . This bit is self-clearing.  O Normal operation.  The internal state of the TBI is reset . This in turn may change the state of the TBI link partner.                                                                                     |                         |                   |  |  |  |  |
|                                            | This field is reserved.                                                                                                                                                                                                                                                              | ge the state of the TD  | or link partiter. |  |  |  |  |
| 1<br>-                                     | Reserved                                                                                                                                                                                                                                                                             |                         |                   |  |  |  |  |
| 2<br>Speed_0                               | Speed selection. This bit defaults to a cleared state and should 1000 Mbps speed. Setting this field controls the speed at which provides the appropriate encoding. Its default is bit[2] = '0'; bit[9]                                                                              | the TBI operates. The   |                   |  |  |  |  |
| 3                                          | Auto-negotiation enable. This bit is set by default.                                                                                                                                                                                                                                 |                         |                   |  |  |  |  |
| AN_Enable                                  | <ul><li>The values programmed in bits 2, 7 and 9 determine the op</li><li>Auto-negotiation process enabled.</li></ul>                                                                                                                                                                | erating condition of th | e link.           |  |  |  |  |
| 4–5<br>-                                   | This field is reserved. Reserved                                                                                                                                                                                                                                                     |                         |                   |  |  |  |  |
| 6<br>Reset_AN                              | Reset auto-negotiation. This bit is cleared by default and is self-clearing.  O Normal operation.  The auto-negotiation process restarts. This action is only available if auto-negotiation is enabled.                                                                              |                         |                   |  |  |  |  |
| 7 Duplex mode. This bit is set by default. |                                                                                                                                                                                                                                                                                      |                         |                   |  |  |  |  |
| Full_Duplex                                | 0 Reserved. 1 Full-duplex operation.                                                                                                                                                                                                                                                 |                         |                   |  |  |  |  |
| 8 -                                        | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                 |                         |                   |  |  |  |  |
| 9<br>Speed_1                               | Speed selection. This bit defaults to a set state and should always be set, which corresponds to 1000 Mbps speed. Setting this field controls the speed at which the TBI operates. The following table provides the appropriate encoding. Its default is bit[2] = '0'; bit[9] = '1'. |                         |                   |  |  |  |  |
|                                            | Maximum Operating Speed                                                                                                                                                                                                                                                              | Bit 2                   | Bit 9             |  |  |  |  |
|                                            | Reserved                                                                                                                                                                                                                                                                             | 0                       | 0                 |  |  |  |  |
|                                            | Reserved                                                                                                                                                                                                                                                                             | 1                       | 0                 |  |  |  |  |
|                                            | 1000 Mbps                                                                                                                                                                                                                                                                            | 0                       | 1                 |  |  |  |  |

## TBI\_MII\_Register\_Set\_CR field descriptions (continued)

| Field | Description                      |       |       |  |  |  |
|-------|----------------------------------|-------|-------|--|--|--|
|       | Maximum Operating Speed          | Bit 2 | Bit 9 |  |  |  |
|       | Reserved                         | 1     | 1     |  |  |  |
| 10–15 | This field is reserved. Reserved |       |       |  |  |  |

# 15.8.2 Status (TBI\_MII\_Register\_Set\_SR)





## TBI\_MII\_Register\_Set\_SR field descriptions

| Field              | Description                                                                                                                                                                                                                                                   |  |  |  |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0–6<br>-           | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                          |  |  |  |  |  |
| 7 Extend_Status    | This bit indicates that PHY status information is also contained in the Register 15, Extended Status Register. Returns 1 on read. This bit is read-only.                                                                                                      |  |  |  |  |  |
| 8 -                | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                          |  |  |  |  |  |
| 9<br>No_Pre        | MF preamble suppression enable. This bit indicates whether or not the PHY is capable of handling MII management frames without the 32-bit preamble field. Returns 1, indicating support for suppressed preamble MII management frames. This bit is read-only. |  |  |  |  |  |
| 10<br>AN_Done      | Auto-negotiation complete. This bit is read-only and is cleared by default.  0 Either the auto-negotiation process is underway or the auto-negotiation function is disabled.  1 The auto-negotiation process has completed.                                   |  |  |  |  |  |
| 11<br>Remote_Fault | Remote fault. This bit is read-only and is cleared by default. Each read of the status register clears this bit.  O Normal operation.  A remote fault condition was detected. This bit latches high in order for software to detect the condition.            |  |  |  |  |  |

## TBI\_MII\_Register\_Set\_SR field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 12<br>AN_Ability     | Auto-negotiation ability. While read as set, this bit indicates that the PHY has the ability to perform auto-negotiation. While read as cleared, this bit indicates the PHY lacks the ability to perform auto-negotiation. Returns 1 on read. This bit is read-only. |  |  |  |  |  |  |
| 13<br>Link_Status    | Link status. This bit is read-only and is cleared by default.  O A valid link is not established. This bit latches low allowing for software polling to detect a failure condition.                                                                                  |  |  |  |  |  |  |
|                      | 1 A valid link is established.                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 14<br>-              | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 15<br>Extend_Ability | Extended capability. This bit indicates that the PHY contains the extended set of registers (those beyond control and status). Returns 1 on read. This bit is read-only.                                                                                             |  |  |  |  |  |  |

# 15.8.3 AN Advertisement Register for 1000Base-X autonegotiation (TBI\_MII\_Register\_Set\_ANA)

## Table 15-1063. PAUSE Priority Resolution

| Local Device |         | Link Partner |         | Local Resolution       | Link Partner Resolution |
|--------------|---------|--------------|---------|------------------------|-------------------------|
| PAUSE        | ASM_DIR | PAUSE        | ASM_DIR |                        |                         |
| 0            | 0       | х            | х       | Disable PAUSE transmit | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Disable PAUSE receive   |
| 0            | 1       | 0            | х       | Disable PAUSE transmit | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Disable PAUSE receive   |
| 0            | 1       | 1            | 0       | Disable PAUSE transmit | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Disable PAUSE receive   |
| 0            | 1       | 1            | 1       | Enable PAUSE transmit  | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Enable PAUSE receive    |
| 1            | 0       | 0            | х       | Disable PAUSE transmit | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Disable PAUSE receive   |
| 1            | 0       | 1            | х       | Enable PAUSE transmit  | Enable PAUSE transmit   |
|              |         |              |         | Enable PAUSE receive   | Enable PAUSE receive    |
| 1            | 1       | 0            | 0       | Disable PAUSE transmit | Disable PAUSE transmit  |
|              |         |              |         | Disable PAUSE receive  | Disable PAUSE receive   |
| 1            | 1       | 0            | 1       | Disable PAUSE transmit | Enable PAUSE transmit   |
|              |         |              |         | Enable PAUSE receive   | Disable PAUSE receive   |
| 1            | 1       | 1            | х       | Enable PAUSE transmit  | Enable PAUSE transmit   |
|              |         |              |         | Enable PAUSE receive   | Enable PAUSE receive    |

#### TBI memory map/register definition

Address: 4h

| Bit           | 0         | 1           | 2           | 3       | 4  | 5        | 6  | 7     |
|---------------|-----------|-------------|-------------|---------|----|----------|----|-------|
| Read<br>Write | Next_Page | Reserved    | Remote      | e_Fault |    | Reserved |    | Pause |
| Reset         | 0         | 0           | 0           | 0       | 0  | 0        | 0  | 0     |
| Bit           | 8         | 9           | 10          | 11      | 12 | 13       | 14 | 15    |
| Read<br>Write | Pause     | Half_Duplex | Full_Duplex |         |    | Reserved |    |       |
| Reset         | 0         | 0           | 0           | 0       | 0  | 0        | 0  | 0     |

## TBI\_MII\_Register\_Set\_ANA field descriptions

| Field               | Description                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0<br>Next_Page      | Next page configuration. The local device sets this bit to either request next page transmission or advertise next page exchange capability.                                                                                              |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
|                     | 0 The local devi                                                                                                                                                                                                                          | The local device wishes not to engage in next page exchange.                                                                                                                                                                                                                               |                                                                                                  |  |  |  |  |  |
|                     | no next pages                                                                                                                                                                                                                             | The local device has no next pages but wishes to allow reception of next pages. If the local device has no next pages and the link partner wishes to send next pages, the local device shall send null message codes and have the message page set to 0b000_0001, as defined in annex 28C. |                                                                                                  |  |  |  |  |  |
| 1 -                 | This field is reserv<br>Reserved. (Ignore                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
| 2–3<br>Remote_Fault | The local device's remote fault condition is encoded in bits 2 and 3 of the base page. Values are shown in the following table. The default value is 00. Indicate a fault by setting a non-zero remote fault encoding and re-negotiating. |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
|                     | RF1 bit[3] RF2 bit[2] Description                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
|                     | 0                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                          | No error, link okay                                                                              |  |  |  |  |  |
|                     | 0                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                          | Offline                                                                                          |  |  |  |  |  |
|                     | 1                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                          | Link_Failure                                                                                     |  |  |  |  |  |
|                     | 1                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                          | Auto-Negotiation_Error                                                                           |  |  |  |  |  |
|                     |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
| 4–6<br>-            |                                                                                                                                                                                                                                           | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                       |                                                                                                  |  |  |  |  |  |
| 7–8<br>Pause        |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                            | s encoded in bits 7 and 8, and the decodes are shown in the information consult the table above. |  |  |  |  |  |
|                     | PAUSE bit[8]                                                                                                                                                                                                                              | ASM_DIR bit[7]                                                                                                                                                                                                                                                                             | Capability                                                                                       |  |  |  |  |  |
|                     | 0                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                          | No PAUSE                                                                                         |  |  |  |  |  |
|                     | 0                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                          | Asymmetric PAUSE toward link partner                                                             |  |  |  |  |  |
|                     | 1                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                          | Symmetric PAUSE                                                                                  |  |  |  |  |  |
|                     | 1                                                                                                                                                                                                                                         | 1 Both symmetric PAUSE and Asymmetric PAUSE toward local device                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |
| 9<br>Half_Duplex    | Half-duplex capability.  O Designates local device as not capable of half-duplex operation.  Designates local device as capable of half-duplex operation.                                                                                 |                                                                                                                                                                                                                                                                                            |                                                                                                  |  |  |  |  |  |

### TBI\_MII\_Register\_Set\_ANA field descriptions (continued)

| Field             | Description                                                                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10<br>Full_Duplex | Full-duplex capability.  O Designates the local device as not capable of full-duplex operation.  Designates the local device as capable of full-duplex operation. |
| 11–15<br>-        | This field is reserved. Reserved, should be cleared.                                                                                                              |

# 15.8.4 AN Advertisement Register for SGMII auto-negotiation (TBI\_MII\_Register\_Set\_ANA\_SGMII)

Following figure describes the definition for the ANA register for SGMII autonegotiation.

Address: 4h



TBI\_MII\_Register\_Set\_ANA\_SGMII field descriptions

| Field    | Description                               |
|----------|-------------------------------------------|
| 0        | Must be set to 0                          |
| -        |                                           |
| 1        | Ignore on read.                           |
| -        |                                           |
| 2–14     | This field is reserved.                   |
| -        | Must be set to 0.                         |
|          | SGMII Auto-negotiation. Must be set to 1. |
| SGMII_AN |                                           |

# 15.8.5 AN Link Partner Base Page Ability Register for 1000Base-X auto-negotiation (TBI\_MII\_Register\_Set\_ANLPBPA)

Address: 5h



#### TBI\_MII\_Register\_Set\_ANLPBPA field descriptions

| Field                    | Description                                                                                                                                                                                                                                                                 |                |                                                               |  |  |  |  |  |  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------|--|--|--|--|--|--|
| 0<br>Next_Page           | Next page. This bit is read-only. The link partner sets or clears this bit.  Unk partner has no subsequent next pages or is not capable of receiving next pages.  Link partner either requesting next page transmission or indicating the capability to receive next pages. |                |                                                               |  |  |  |  |  |  |
| 1<br>-                   | This field is reserved. (Ignore                                                                                                                                                                                                                                             |                |                                                               |  |  |  |  |  |  |
| 2–3<br>Remote_Fault      |                                                                                                                                                                                                                                                                             |                |                                                               |  |  |  |  |  |  |
|                          | RF1 bit[3] RF2 bit[2] Description                                                                                                                                                                                                                                           |                |                                                               |  |  |  |  |  |  |
|                          | 0                                                                                                                                                                                                                                                                           | 0              | No error, link okay                                           |  |  |  |  |  |  |
|                          | 0                                                                                                                                                                                                                                                                           | 1              | Offline                                                       |  |  |  |  |  |  |
|                          | 1                                                                                                                                                                                                                                                                           | 0              | Link_Failure                                                  |  |  |  |  |  |  |
|                          | 1                                                                                                                                                                                                                                                                           | 1              | Auto-Negotiation_Error                                        |  |  |  |  |  |  |
| 4–6<br>-<br>7–8<br>Pause | This field is reserved. Reserved, should be cleared. Encoding of the link partner's PAUSE capability is shown in the PAUSE encoding table below. For priority resolution information consult. This bit is read-only                                                         |                |                                                               |  |  |  |  |  |  |
|                          |                                                                                                                                                                                                                                                                             |                |                                                               |  |  |  |  |  |  |
|                          | PAUSE bit[8]                                                                                                                                                                                                                                                                | ASM_DIR bit[7] | Capability                                                    |  |  |  |  |  |  |
|                          | 0                                                                                                                                                                                                                                                                           | 0              | No PAUSE                                                      |  |  |  |  |  |  |
|                          | 0                                                                                                                                                                                                                                                                           | 1              | Asymmetric PAUSE toward link partner                          |  |  |  |  |  |  |
|                          | 1                                                                                                                                                                                                                                                                           | 0              | Symmetric PAUSE                                               |  |  |  |  |  |  |
|                          | 1                                                                                                                                                                                                                                                                           | 1              | Both symmetric PAUSE and Asymmetric PAUSE toward local device |  |  |  |  |  |  |

Table continues on the next page...

## TBI\_MII\_Register\_Set\_ANLPBPA field descriptions (continued)

| Field             | Description                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------|
| 9<br>Half_Duplex  | Half-duplex capability. This bit is read-only.  Unit partner is not capable of half-duplex mode. |
|                   | 1 Link partner is capable of half-duplex mode.                                                   |
| 10<br>Full Duplex | Full-duplex capability. This bit is read-only.                                                   |
|                   | 0 Link partner is not capable of full-duplex mode.                                               |
|                   | 1 Link partner is capable of full-duplex mode.                                                   |
| 11–15<br>-        | This field is reserved. Reserved, should be cleared.                                             |

# 15.8.6 AN Link Partner Base Page Ability Register for SGMII auto-negotiation (TBI\_MII\_Register\_Set\_ANLPBPA\_SGMII)

Following figure describes the definition for the ANLPBPA register for SGMII autonegotiation.

Address: 5h



TBI\_MII\_Register\_Set\_ANLPBPA\_SGMII field descriptions

| Field            | Description                                                                  |
|------------------|------------------------------------------------------------------------------|
| 0<br>Link_Status | Link status. The link partner sets or clears this bit.  Unit down.  Link up. |
| 1–2              | This field is reserved. Ignore on read.                                      |
| 3<br>Duplex_Mode | Duplex mode.The link partner sets or clears this bit.                        |

Table continues on the next page...

## TBI\_MII\_Register\_Set\_ANLPBPA\_SGMII field descriptions (continued)

| Field            |                                                          | Description                        |                                                                       |  |  |  |  |  |
|------------------|----------------------------------------------------------|------------------------------------|-----------------------------------------------------------------------|--|--|--|--|--|
|                  | 0 Half duplex                                            |                                    |                                                                       |  |  |  |  |  |
|                  | 1 Full duplex                                            |                                    |                                                                       |  |  |  |  |  |
| 4–5<br>Speed_Bit | Speed Bit. The er                                        | ncoding of the link s              | peed select is listed below. The link partner sets or clears this bit |  |  |  |  |  |
|                  | Speed bit[5]                                             | Speed bit[4]                       | Capability                                                            |  |  |  |  |  |
|                  | 0                                                        | 0                                  | 10 Mbps: 10BASET, 10BASE2, 10BASE5                                    |  |  |  |  |  |
|                  | 0                                                        | 1 100 Mbps: 100BASE-TX, 100BASE-FX |                                                                       |  |  |  |  |  |
|                  | 1                                                        | 0                                  | 1000 Mbps: 1000BASE-TX, 1000BASE-X                                    |  |  |  |  |  |
|                  | 1                                                        | 1                                  | Reserved                                                              |  |  |  |  |  |
|                  |                                                          | •                                  |                                                                       |  |  |  |  |  |
| 6–14             | This field is reserved.                                  |                                    |                                                                       |  |  |  |  |  |
| -                |                                                          |                                    |                                                                       |  |  |  |  |  |
| 15               | SGMII AN mode. The link partner sets or clears this bit. |                                    |                                                                       |  |  |  |  |  |
| SGMII_AN         | Always set to 1 after SGMII AN is done.                  |                                    |                                                                       |  |  |  |  |  |

# 15.8.7 AN expansion (TBI\_MII\_Register\_Set\_ANEX)





### TBI\_MII\_Register\_Set\_ANEX field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0–12<br>-      | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                |  |  |  |  |  |
| 13<br>NP_Able  | Next page able. This bit is read-only and returns 1 on read. While read as set, indicates local device supports next page function.                                                                                                                                                                                 |  |  |  |  |  |
| 14<br>Page_Rxd | <ul> <li>Page received. This bit is read-only. The bit clears on a read to the register.</li> <li>Normal operation.</li> <li>A new page was received and stored in the applicable AN link partner ability or AN next page register. This bit latches high in order for software to detect while polling.</li> </ul> |  |  |  |  |  |
| 15<br>-        | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                |  |  |  |  |  |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 15.8.8 AN next page transmit (TBI\_MII\_Register\_Set\_ANNPT)

Address: 7h



#### TBI\_MII\_Register\_Set\_ANNPT field descriptions

| Field                                          | Description                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Next_Page                                 | Next page indication. [Reference MII bit 7.15 in IEEE 802.3, 2000 Edition , Clause 28.2.4]                                                                                                                                                                                                                                                               |
|                                                | Last page.     Additional next pages to follow.                                                                                                                                                                                                                                                                                                          |
| 1                                              | Additional next pages to follow.  This field is reserved.                                                                                                                                                                                                                                                                                                |
| -                                              | Reserved. (Ignore on read)                                                                                                                                                                                                                                                                                                                               |
| 2<br>Msg_Page                                  | Message page. [Reference MII bit 7.13]                                                                                                                                                                                                                                                                                                                   |
| <u>og_</u> . age                               | 0 Unformatted page.                                                                                                                                                                                                                                                                                                                                      |
|                                                | 1 Message page.                                                                                                                                                                                                                                                                                                                                          |
| 3<br>Ack2                                      | Acknowledge 2. Used by the next page function to indicate that the device has the ability to comply with the message. [Reference MII bit 7.12]                                                                                                                                                                                                           |
|                                                | 0 The local device cannot comply with message.                                                                                                                                                                                                                                                                                                           |
|                                                | 1 The local device complies with message.                                                                                                                                                                                                                                                                                                                |
| 4<br>Toggle                                    | Toggle. Used to ensure synchronization with the link partner during next page exchange. This bit always takes the opposite value of the toggle bit of the previously-exchanged link code word. The initial value in the first next page transmitted is the inverse of bit 11 in the base link code word. [Reference MII bit 7.11] This bit is read-only. |
|                                                | 0 Toggle bit of the previously-exchanged link code word was 1.                                                                                                                                                                                                                                                                                           |
|                                                | 1 Toggle bit of the previously-exchanged link code word was 0.                                                                                                                                                                                                                                                                                           |
| 5-15<br>Message_<br>Unformatted_<br>Code_Field | Message pages are formatted pages that carry a pre-defined message code, which is enumerated in IEEE 802.3u/Annex 28C. Unformatted code fields take on an arbitrary value. [Reference MII field 7.10:0]                                                                                                                                                  |

# 15.8.9 AN link partner ability next page (TBI\_MII\_Register\_Set\_ANLPANP)

Address: 8h



#### TBI\_MII\_Register\_Set\_ANLPANP field descriptions

| Field                                          | Description                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Next_Page                                 | Next page. The link partner sets and clears this bit.                                                                                                                                                                                                                                                                           |
| ivext_i age                                    | 0 Last page from link partner                                                                                                                                                                                                                                                                                                   |
|                                                | 1 Additional next pages to follow                                                                                                                                                                                                                                                                                               |
| 1 -                                            | This field is reserved. Reserved. (Ignore on read)                                                                                                                                                                                                                                                                              |
| 2<br>Msg_Page                                  | Message page.  0 Unformatted page                                                                                                                                                                                                                                                                                               |
|                                                | 1 Message page                                                                                                                                                                                                                                                                                                                  |
| 3<br>Ack2                                      | Acknowledge 2. Indicates the link partner's ability to comply with the message.                                                                                                                                                                                                                                                 |
|                                                | 0 Link partner cannot comply with message.                                                                                                                                                                                                                                                                                      |
|                                                | 1 Link partner complies with message.                                                                                                                                                                                                                                                                                           |
| 4<br>Toggle                                    | Toggle. Used to ensure synchronization with the link partner during next page exchange. This bit always takes the opposite value of the toggle bit of the previously-exchanged link code word. The initial value in the first next page transmitted is the inverse of bit 11 in the base link code word. This bit is read-only. |
|                                                | 0 Toggle bit of the previously-exchanged link code word was 1.                                                                                                                                                                                                                                                                  |
|                                                | 1 Toggle bit of the previously-exchanged link code word was 0.                                                                                                                                                                                                                                                                  |
| 5–15<br>Message_<br>Unformatted_<br>Code_Field | Message pages are formatted pages that carry a pre-defined message code, which is enumerated in IEEE 802.3u/Annex 28C. Unformatted code fields take on an arbitrary value.                                                                                                                                                      |

# 15.8.10 Extended status (TBI\_MII\_Register\_Set\_EXST)

Address: Fh



#### TBI\_MII\_Register\_Set\_EXST field descriptions

| Field           | Description                                                             |
|-----------------|-------------------------------------------------------------------------|
| 0<br>1000X_Full | 1000X full-duplex capability. Returns 1 on read. This bit is read-only. |
|                 | 0 PHY cannot operation in 1000BASE-X full-duplex mode.                  |
|                 | 1 PHY can operate in 1000BASE-X full-duplex mode.                       |
| 1<br>1000X_Half | 1000X half-duplex capability. Returns 0 on read. This bit is read-only. |
|                 | 0 PHY cannot operation in 1000BASE-X half-duplex mode.                  |
|                 | 1 PHY can operate in 1000BASE-X half-duplex mode.                       |
| 2<br>1000T_Full | 1000T full-duplex capability. Returns 1 on read. This bit is read-only. |
|                 | 0 PHY cannot operation in 1000BASE-T full-duplex mode.                  |
|                 | 1 PHY can operate in 1000BASE-T full-duplex mode.                       |
| 3<br>1000T_Half | 1000T half-duplex capability. Returns 0 on read. This bit is read-only. |
|                 | 0 PHY cannot operation in 1000BASE-T half-duplex mode.                  |
|                 | 1 PHY can operate in 1000BASE-T half-duplex mode.                       |
| 4–15            | This field is reserved.                                                 |
| -               | Reserved                                                                |

Address: 10h

# 15.8.11 Jitter diagnostics (TBI\_MII\_Register\_Set\_JD)

Annex 36A in IEEE 802.3z describes several jitter test patterns. These can be configured to be sent by writing the jitter diagnostics register. See the register description for more information. It may be wise to auto-negotiate and advertise a remote fault signaling of offline prior to beginning the test patterns.

| Bit           | 0                     | 1 | 2             | 3  | 4    | 5     | 6         | 7            |
|---------------|-----------------------|---|---------------|----|------|-------|-----------|--------------|
| Read<br>Write | Jitter_<br>Enable     |   | Jitter_Select |    | Rese | erved | Custom_Ji | tter_Pattern |
| Reset         | 0                     | 0 | 0             | 0  | 0    | 0     | 0         | 0            |
| Bit           | 8                     | 9 | 10            | 11 | 12   | 13    | 14        | 15           |
| Read<br>Write | Custom_Jitter_Pattern |   |               |    |      |       |           |              |
| Reset         | 0                     | 0 | 0             | 0  | 0    | 0     | 0         | 0            |

#### TBI\_MII\_Register\_Set\_JD field descriptions

| Field                | Description                                                                                                                                                      |        |          |        |  |  |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------|--------|--|--|--|--|
| 0<br>Jitter_Enable   | Jitter enable . This bit is cleared by default.  0 Normal transmit operation.  1 Enable the TBI to transmit the jitter test patterns defined in IEEE 802.3z 36A. |        |          |        |  |  |  |  |
| 1–3<br>Jitter_Select | Selects the jitter pattern to be transmitted in diagnostics mode . Encoding following table . Default is 00.                                                     |        | shown in | the    |  |  |  |  |
|                      | Jitter Pattern Select                                                                                                                                            | bit[1] | bit[2]   | bit[3] |  |  |  |  |
|                      | User defined uses custom jitter pattern, bits 6-15                                                                                                               | 0      | 0        | 0      |  |  |  |  |
|                      | High frequency (+/- D21.5) 10101010101010101010101010101010101010                                                                                                | 0      | 0        | 1      |  |  |  |  |
|                      | Mixed frequency (+/- K28.5) 1111101011000001010011111010110000010100                                                                                             | 0      | 1        | 0      |  |  |  |  |
|                      | Low frequency 111111000001111110000011111100000                                                                                                                  | 0      | 1        | 1      |  |  |  |  |
|                      | Complex pattern (10'h17c,10'h0c9,10'h0e5,10'h2a3, 10'h17c,)                                                                                                      | 1      | 0        | 0      |  |  |  |  |
|                      | Square Wave (- K28.7) 001111100000111110000011111000                                                                                                             | 1      | 0        | 1      |  |  |  |  |
|                      | Reserved                                                                                                                                                         | 1      | 1        | 0      |  |  |  |  |
|                      | Reserved                                                                                                                                                         | 1      | 1        | 1      |  |  |  |  |

Table continues on the next page...

## TBI\_MII\_Register\_Set\_JD field descriptions (continued)

| Field                             | Description                                                                                                                                                                             |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4–5<br>-                          | This field is reserved. Reserved                                                                                                                                                        |
| 6–15<br>Custom_Jitter_<br>Pattern | Used in conjunction with jitter (pattern) select and jitter (diagnostic) enable; set this field to the desired custom pattern which is continuously transmitted . Its default is 0x000. |

# 15.8.12 TBI control (TBI\_MII\_Register\_Set\_TBICON)





#### TBI\_MII\_Register\_Set\_TBICON field descriptions

| Field           | Description                                                                                                                                                                                         |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Soft_Reset | Soft reset . This bit is cleared by default.                                                                                                                                                        |
|                 | 0 Normal operation.                                                                                                                                                                                 |
|                 | 1 Resets the functional modules in the TBI.                                                                                                                                                         |
| 1               | This field is reserved.                                                                                                                                                                             |
| -               | Reserved. (Ignore on read)                                                                                                                                                                          |
| 2               | Disable receive disparity . This bit is cleared by default.                                                                                                                                         |
| Disable_Rx_Dis  |                                                                                                                                                                                                     |
|                 | 0 Normal operation.                                                                                                                                                                                 |
|                 | 1 Disables the running disparity calculation and checking in the receive direction.                                                                                                                 |
| 3               | Disable transmit disparity . This bit is cleared by default.                                                                                                                                        |
| Disable_Tx_Dis  | 0 Normal operation.                                                                                                                                                                                 |
|                 | ·                                                                                                                                                                                                   |
|                 | 1 Disables the running disparity calculation and checking in the transmit direction.                                                                                                                |
| 4–6             | This field is reserved.                                                                                                                                                                             |
| -               | Reserved                                                                                                                                                                                            |
| 7               | Auto-negotiation sense enable. This bit is cleared by default.                                                                                                                                      |
| AN_Sense        |                                                                                                                                                                                                     |
|                 | 0 IEEE 802.3z Clause 37 behavior is desired, which results in the link not completing.                                                                                                              |
|                 | Allow the auto-negotiation function to sense either a Gigabit MAC in auto-negotiation bypass mode or an older Gigabit MAC without auto-negotiation capability. If sensed, auto-negotiation complete |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### TBI\_MII\_Register\_Set\_TBICON field descriptions (continued)

| Field          | Description                                                                                                             |
|----------------|-------------------------------------------------------------------------------------------------------------------------|
|                | becomes true; however, the page received is low, indicating no page was exchanged. Management can then act accordingly. |
| 8–9<br>-       | This field is reserved. Reserved                                                                                        |
| 10             | Clock select . This bit selects how the on-chip TBI PHY is clocked.                                                     |
| Clock_Select   | This bit is cleared by default.                                                                                         |
|                | If operating in SGMII mode:                                                                                             |
|                | 0 Disable the TBI PHY clock.                                                                                            |
|                | 1 Enable the TBI PHY clock (required for SGMII operation). This clock is provided on-chip by the SerDes block.          |
| 11<br>MII_Mode | This bit describes the configuration mode of the TBI. Its value is the inverse of ECNTRL[TBIM].                         |
| _              | 0 TBI mode (connected to a 1000BASE-X SerDes)                                                                           |
|                | 1 Reserved                                                                                                              |
| 12–15<br>-     | This field is reserved. Reserved                                                                                        |

# 15.9 Functional description

This section describes the following:

- Programming model considerations
- Connecting to physical interfaces on Ethernet
- Gigabit Ethernet controller channel operation
- TCP/IP offload
- Quality of service (QoS) provision
- Lossless flow control
- Hardware assist for IEEE Std. 1588 compliant timestamping
- Buffer descriptors

# 15.9.1 Programming model considerations

The eTSECs use a software model that is a superset of the PowerQUICC III TSEC functionality and is similar to that employed by the Fast Ethernet function supported on the Freescale MPC8260 CPM FCC and in the FEC of the MPC860T.

The eTSEC device is programmed by a combination of control/status registers (CSRs) and buffer descriptors. The CSRs are used for mode control, interrupts, and to extract status information. The descriptors are used to pass data buffers and related buffer status or frame information between the hardware and software.

All accesses to and from the registers must be made as 32-bit accesses. There is no support for accesses of sizes other than 32 bits. Writes to reserved register bits must always store 0, as writing 1 to reserved bits may have unintended side-effects. Reads from unmapped register addresses return zero. Unless otherwise specified, the read value of reserved bits in mapped registers is not defined, and must not be assumed to be 0.

This section of the document defines the memory map and describes the registers in detail. The buffer descriptor is described in Buffer descriptors.

The ten-bit interface (TBI) module MII registers, are described in Ten-bit interface (TBI). The TBI registers are defined similar to PHY registers and are accessed through the MII management interface in the same way the PHYs are accessed. These registers are also used for SGMII.

# 15.9.1.1 MAC functionality

This section describes the MAC registers at a high level and provides a brief overview of the functionality that can be exercised through the use of these registers, particularly those that provide functionality not explicitly required by the IEEE 802.3 standard.

All of the MAC registers are 32 bits wide. MAC register descriptions are found starting with MAC configuration register 1 (eTSEC\_MACCFG1).

# 15.9.1.1.1 Configuring the MAC

The MAC configuration registers 1 and 2 provide for configuring the MAC in the following ways:

- Adjusting the preamble length-The length of the preamble can be adjusted from the nominal seven bytes to some other (≥3 byte) value. Should custom preamble insertion/extraction be configured, then this register must by left at its default value of 7.
- Varying pad/CRC combinations-Three different pad/CRC combinations are provided to handle a variety of system requirements. Simplest are frames that already have a valid frame check sequence (FCS) field. The other two options include appending a valid CRC or padding and then appending a valid CRC, resulting in a minimum frame of 64 octets. In addition to the programmable register set, the pad/CRC behavior can be dynamically adjusted on a per-packet basis.

## 15.9.1.1.2 Controlling CSMA/CD

The half-duplex register (HAFDUP) allows control over the carrier-sense multiple access/collision detection (CSMA/CD) logic of the eTSEC.

Half-duplex mode is only supported for 10- and 100-Mbps operation. Following the completion of the packet transmission the part begins timing the inter packet gap (IPG) as programmed in the back-to-back IPG configuration register. The system is now free to begin another frame transfer.

In full-duplex mode both the carrier sense (CRS) and collision (COL) indications from the PHY are ignored, but in half-duplex mode the eTSEC defers to CRS, and following a carrier event, times the IPG using the non-back-to-back IPG configuration values that include support for the optional two-thirds/one-third CRS deferral process. This optional IPG mechanism enhances system robustness and ensures fair access to the medium. During the first two-thirds of the IPG, the IPG timer is cleared if CRS is sensed. During the final one-third of the IPG, CRS is ignored and the transmission begins once IPG is timed. The two-thirds/one-third ratio is the recommended value.

### 15.9.1.1.3 Handling packet collisions

While transmitting a packet in half-duplex mode, the eTSEC is sensitive to COL.

If a collision occurs, it aborts the packet and outputs the 32-bit jam sequence. The jam sequence is comprised of several bits of the CRC, inverted to guarantee an invalid CRC upon reception. A signal is sent to the system indicating that a collision occurred and that the start of the frame is needed for retransmission. The eTSEC then backs off of the medium for a time determined by the truncated binary exponential back off (BEB) algorithm. Following this back-off time, the packet is retried. The back-off time can be skipped if configured through the half-duplex register. However, this is non-standard behavior and its use must be carefully applied. Should any one packet experience excessive collisions, the packet is aborted. The system should flush the frame and move to the next one in line. If the system requests to send a packet while the eTSEC is deferring to a carrier, the eTSEC simply waits until the end of the carrier event and the timing of IPG before it honors the request.

If packet transmission attempts experience collisions, the eTSEC outputs the jam sequence and waits some amount of time before retrying the packet. This amount of time is determined by a controlled randomization process called truncated binary exponential back-off. The amount of time is an integer number of slot times. The number of slot times to delay before the *n*th retransmission attempt is chosen as a uniformly-distributed random integer *r* in the range:

 $0 \le r \le 2^{k}$ , where  $k = \min(n, 10)$ .

So after the first collision, the eTSEC backs off either 0 or 1 slot times. After the fifth collision, the eTSEC backs off between 0 and 32 slot times. After the tenth collision, the maximum number of slot times to back off is 1024. This can be adjusted through the half-duplex register. An alternate truncation point, such as 7 for instance, can be programmed. On average, the MAC is more aggressive after seven collisions than other stations on the network.

Note that there is no COL/CRS in RGMII or SGMII. Instead, COL and CRS are derived from the equivalents of RX\_DV and TX\_EN.

### 15.9.1.1.4 Controlling packet flow

Packet flow can be dealt with in a number of ways within eTSEC.

A default retransmit attempt limit of 15 can be reduced using the half-duplex register. The slot time or collision window can be used to gate the retry window and possibly reduce the amount of transmit buffering within the system. The slot time for 10/100 Mbps is 512 bit times. Because the slot time begins at the beginning of the packet (including preamble), the end occurs around the 56th byte of the frame data. Slot time in 1000-Mbps mode is not supported.

Full-duplex flow control is provided for in IEEE 802.3x. Currently the standard does not address flow control in half-duplex environments. Common in the industry, however, is the concept of back pressure. The eTSEC implements the optional back pressure mechanism using the raise carrier method. If the system receive logic wishes to stop the reception of packets in a network-friendly way, transmit half-duplex flow control (THDF) is set (TCTRL[THDF]). If the medium is idle, the eTSEC raises carrier by transmitting preamble. Other stations on the half-duplex network then defer to the carrier.

In the event the preamble transmission happens to cause a collision, the eTSEC ensures the minimum 96-bit presence on the wire, then drops preamble and waits a back-off time depending on the value of the back-pressure-no-back-off configuration bit HAFDUP[BP No BackOff]. These transmitting-preamble-for-back pressure collisions are not counted. If HAFDUP[BP No BackOff] is set, the eTSEC waits an inter-packet gap before resuming the transmission of preamble following the collision and does not defer. If HAFDUP[BP No BackOff] is cleared, the eTSEC adheres to the truncated BEB algorithm that allows the possibility of packets being received. This also can be detrimental in that packets can now experience excessive collisions, causing them to be dropped in the stations from which they originate. To reduce the likelihood of lost packets and packets leaking through the back pressure mechanism, HAFDUP[BP No BackOff] must be set.

The eTSEC drops carrier (cease transmitting preamble) periodically to avoid excessive defer conditions in other stations on the shared network. If, while applying back pressure, the eTSEC is requested to send a packet, it stops sending preamble, and waits one IPG before sending the packet. HAFDUP[BP No BackOff] applies for any collision that occurs during the sending of this packet. Collisions for packets while half duplex back pressure is asserted are counted. The eTSEC does not defer while attempting to send packets while in back pressure. Again, back pressure is non-standard, yet it can be effective in reducing the flow of receive packets.

## 15.9.1.1.5 Controlling PHY links

Control and status to and from the PHY is provided through the two-wire MII management interface described in IEEE 802.3u.

The MII management registers (MII management configuration, command, address, control, status, and indicator registers) are used to exercise this interface between a host processor and one or more PHY devices.

The eTSEC MII's registers provide the ability to perform continuous read cycles (called a scan cycle); although, scan cycles are not explicitly defined in the standard. If requested (by setting MIIMCOM[Scan Cycle]), the part performs repetitive read cycles of the PHY status register, for example. In this way, link characteristics may be monitored more efficiently. The different fields in the MII management indicator register (scan, not valid and busy) are used to indicate availability of each read of the scan cycle to the host from MIIMSTAT[PHY scan].

Yet another parameter that can be modified through the MII registers is the length of the MII management interface preamble. After establishing that a PHY supports preamble suppression, the host may so configure the eTSEC. While enabled, the length of MII management frames are reduced from 64 clocks to 32 clocks. This effectively doubles the efficiency of the interface.

# 15.9.1.2 MIB registers

This section provides an introduction to the MIB registers; MIB register descriptions begin with Transmit and receive 64-byte frame counter (eTSEC\_TR64).

The eTSEC RMON module has 37 separate statistics counters, which simply count or accumulate statistical events that occur as packets transmitted and received.

These counters support RMON MIB group 1, RMON MIB group 2 if table counters, RMON MIB group 3, RMON MIB group 9, RMON MIB 2, and the 802.3 Ethernet MIB.

An interrupt can be generated upon any one counter's rollover condition through a carry interrupt output from the RMON. Each counter's rollover condition can be discretely masked from causing an interrupt by internal masking registers (CAM1/CAM2).

Each of the counter or carry mask registers is read/writeable. The carry registers are read/write-1-clear. In addition, setting ECNTRL[CLRCNT] automatically clears all the counter and carry registers. If ECNTRL[AUTOZ] is set, each counter and carry register is automatically cleared when read. The carry mask registers are unaffected by CLRCLNT and AUTOZ.

The majority of MIB counters are Ethernet-specific.

#### NOTE

RMON counters do not comprehend custom VLAN tagged frames. Affected counters include TRMGV, RMCA, RBCA, RXCF, RXPF, RXUO, RALN, RFLR, ROVR, RJBR, TMCA, TBCA, TXPF, TXCF. Specifically, custom VLAN tagged frames are not afforded the ability to be greater than 1518, as compared to the IEEE standard tagged frames.

#### **NOTE**

The transmit/receive frame counters (TR64, TR127, TR255, TR511. TR1K, TRMAX, and TRMGV) do not increment for aborted frames (collision retry limit exceeded, late collision, underrun, EBERR, TxFIFO data error, frame truncated due to exceeding MAXFRM, or excessive deferral).

# 15.9.1.3 Hash function registers

Detailed descriptions of the registers used for hash functions are found starting with Individual/group address register n (eTSEC\_IGADDR*n*).

All hash function registers are 32 bits wide.

The DA field of every received frame is processed through a 32-bit CRC generator (CRC-32 polynomial), and the 8 or 9 most significant bits of the CRC are mapped to a hash table entry. The user can enable a hash entry by setting its bit. A hash entry usually represents a set of addresses. A hash table hit occurs if the DA CRC result points to an enabled hash entry. Software may need to further filter the address in order to eliminate false-positive hits in the hash table.

If RCTRL[GHTX] = 0, the 8 most significant bits of the CRC are used as the hash table index. In this case, registers IGADDR0-IGADDR7 comprise a 256-entry hash table exclusively for individual (unicast) address matching, while registers GADDR0-GADDR7 comprise a 256-entry hash table for group (multicast) address matching. If RCTRL[GHTX] = 1, the group hash table is extended to all 512 entries, and the 9 most significant bits of the CRC are used as the hash table index. In this case, registers IGADDR0-IGADDR7 hold hash table entries 0-255 for group addresses, while registers GADDR0-GADDR7 hold entries 256-511 of the extended group hash table.

See Hash table algorithm for more information on the hash algorithm.

## 15.9.1.4 Lossless flow control configuration registers

When enabled through RCTRL[LFC], the eTSEC tracks location of the last free BD in each Rx BD ring through the value of RFBPTR*n*.

Using this pointer and the ring length stored in RQPRMn[LEN], the eTSEC continuously calculates the number of free BDs in the ring. Whenever the calculated number of free BDs in the ring drops below the pause threshold specified in RQPRMn[FBTHR], the eTSEC issues link layer flow control. It continues to assert flow control until the free BD count for each active ring reaches or exceeds RQPRMn[FBTHR]. See Back pressure determination through free buffers, for the theory of operation of these registers.

# 15.9.1.5 Hardware assist for IEEE1588 compliant timestamping

IEEE 1588 compliant time stamping on this device is accomplished using the per-port transmit time stamping registers within each Ethernet controller memory space.

See Tx time stamp identification tag [set n] \* (eTSEC\_TMR\_TXTSn\_ID), Tx time stamp low [set n] \* (eTSEC\_TMR\_TXTSn\_L), and Tx time stamp high [set n] \* (eTSEC\_TMR\_TXTSn\_H) in conjunction with the registers beginning with Timer control register \* (eTSEC1\_TMR\_CTRL), which are located within the memory space for eTSEC1. Because the common 1588 time stamping registers exist within the eTSEC1 memory space, the eTSEC1 controller must remain enabled in order to use 1588 time stamping for any Ethernet port.

# 15.9.1.6 Interrupt steering and coalescing registers

All interrupt lines are operated either in single-group mode or multigroup mode.

For a description, refer to Interrupt steering register group n (eTSEC\_ISRGn). When in single-group mode, all Rx, Tx, and error interrupts are driven to group 0. When in multigroup mode, the following choices are given to software to either steer interrupts to group 0, or group 1. Interrupts can be Rx, Tx, or error interrupts.

Table 15-1073. Interrupt routing in single-group and multigroup mode

| Interrupt type | Interrupt source           | Mode         | Register setting   | Interrupt destination   |
|----------------|----------------------------|--------------|--------------------|-------------------------|
| All            | All                        | Single-group | ISRG0n == 0        | Group 0 interrupts      |
| Transmit       | IEVENTGg[TXB] from ring r  | Multi-group  | ISRGn[TRm] = 1     | Group g Tx interrupt    |
|                | IEVENTGg[TXF] from ring r  |              |                    |                         |
| Receive        | IEVENTGg[RXF] from ring r  |              | ISRGn[RRm] = 1     | Group g Rx interrupt    |
|                | IEVENTGg[RXB] from ring r  |              |                    |                         |
|                | IEVENTGg[FGPI] from ring r |              |                    |                         |
| Error          | IEVENTGg[BABR]             |              | EMAPG[BABRGP] = n  | Group g error interrupt |
|                | IEVENTGg[RXC]              |              | EMAPG[RXCGP] = n   |                         |
|                | IEVENTGg[BSY] from ring r  |              | ISRGn[RRm] = 1     |                         |
|                | IEVENTGg[EBERR]            |              | EMAPG[EBERRGP] = n |                         |
|                | IEVENTGg[MSRO]             |              | EMAPG[MSROGP] = n  |                         |
|                | IEVENTGg[GTSC]             |              | EMAPG[GTSCGP] = n  |                         |
|                | IEVENTGg[BABT]             |              | EMAPG[BABTGP] = n  |                         |
|                | IEVENTGg[TXC]              |              | EMAPG[TXCGP] = n   |                         |
|                | IEVENTGg[LC]               |              | EMAPG[LCGP] = n    |                         |
|                | IEVENTGg[CRL]              |              | EMAPG[CRLGP] = n   |                         |
|                | IEVENTGg[XFUN]             |              | EMAPG[XFUNGP] = n  |                         |
|                | IEVENTGg[MAG]              |              | EMAPG[MAGGP] = n   |                         |
|                | IEVENTGg[GRSC]             |              | EMAPG[GRSCGP] = n  |                         |
|                | IEVENTGg[FIR]              |              | EMAPG[FIRGP] = n   |                         |
|                | IEVENTGg[FIQ]              |              | EMAPG[FIQGP] = n   |                         |
|                | IEVENTGg[DPE]              |              | EMAPG[DPEGP] = n   |                         |
|                | IEVENTGg[PERR]             |              | EMAPG[PERRGP] = n  |                         |
|                | IEVENTM[MMRD]              |              | EMAPM[MMRDGP] = n  |                         |
|                | IEVENTM[MMWR]              |              | EMAPM[MMWRGP] = n  |                         |

# 15.9.1.7 Ten-bit interface (TBI)

This section describes the ten-bit interface (TBI/RTBI) and the TBI MII set of registers. These registers are used in SGMII mode.

# 15.9.2 Connecting to physical interfaces on Ethernet

This section describes how to connect the eTSEC to various interface(s): MII,RMII, RGMII.

To avoid confusion, all of the buses follow the bus conventions used in the IEEE 802.3 specification because the PHYs follow the same conventions. (For instance, in the bus TSEC*n*\_TXD[ 3:0], bit 3 is the msb and bit 0 is the lsb). If a mode does not use all input signals available to a particular eTSEC, those inputs that are not used must be pulled low on the board.

# 15.9.2.1 Media-independent interface (MII)

This section describes the media-independent interface (MII) intended to be used between the PHYs and the eTSEC.

The figure below depicts the basic components of the MII including the signals required to establish eTSEC module connection with a PHY.



The management signals (MDC and MDIO) are common to all of the Ethernet controllers' connections in the system, assuming that each PHY has a different management address.

Figure 15-1058. eTSEC-MII connection

An MII interface has 18 signals (including the MDC and MDIO signals), as defined by the IEEE 802.3u standard, for connecting to an Ethernet PHY.

# 15.9.2.2 Reduced media-independent interface (RMII)

This section describes the reduced media-independent interface (RMII) intended to be used between the PHYs and the GMII MAC.

The RMII is a reduced-pin alternative to the IEEE802.3u MII. The RMII reduces the number of signals required to interconnect the MAC and the PHY from a maximum of 18 signals (MII) to 10 signals. To accomplish this objective, the data paths are halved in width and clocked at twice the MII clock frequency, while clocks, carrier sense and error signals have been partly combined. For 100 Mbps operation, the reference clock operates at 50 MHz, whereas for 10 Mbps operation, the clock remains at 50MHz, but only every 10th cycle is used. The figure below depicts the basic components of the reduced media-independent interface and the signals required to establish an eTSEC's connection with a PHY. The RMII is implemented as defined by the RMII Specification of the RMII Consortium, as of March 20, 1998.



The management signals (MDC and MDIO) are common to all of the Ethernet controllers module connections in the system, assuming that each PHY has a different management address.

Figure 15-1059. eTSEC-RMII connection

# 15.9.2.3 Reduced gigabit media-independent interface (RGMII)

This section describes the reduced gigabit media-independent interface (RGMII) intended to be used between the PHYs and the GMII MAC.

The RGMII is an alternative to the IEEE 802.3u MII. The RGMII reduces the number of signals required to interconnect the MAC and the PHY from a maximum of 28 signals (GMII) to 15 signals (GTX\_CLK125 included) in a cost effective and technology

independent manner. To accomplish this objective, the data paths and all associated control signals are multiplexed using both edges of the clock. For gigabit operation, the clocks operate at 125MHz, and for 10/100 operation, the clocks operate at 2.5 MHz or 25 MHz, respectively. Note that the GTX\_CLK125 input must be provided at 125 MHz for an RGMII interface, regardless of operation speed (1 Gbps, 100 Mbps, or 10 Mbps).

The figure below depicts the basic components of the gigabit reduced media-independent interface and the signals required to establish the gigabit Ethernet controllers' module connection with a PHY. The RGMII is implemented as defined by the RGMII specification, version 1.2a.



The management signals (MDC and MDIO) are common to all of the gigabit Ethernet controllers module connections in the system, assuming that each PHY has a different management address.

Figure 15-1060. eTSEC-RGMII connection

# 15.9.2.4 Serial gigabit media-independent interface (SGMII)

This section describes the serial gigabit media-independent interface (SGMII) intended to be used between a SerDes PHY and the eTSEC to implement a serial gigabit version of a media-independent interface.

The figure below depicts the basic components of the SGMII including the signals required to establish eTSEC module connection with a PHY. Note that in SGMII the eTSEC utilizes the on-chip TBI PHY in addition to the SerDes interface.



<sup>&</sup>lt;sup>1</sup> The management signals (MDC and MDIO) may be common to all of the Ethernet controllers' connections in the system, assuming that each PHY has a different management address.

Figure 15-1061. eTSEC-SGMII connection

#### 15.9.2.5 SGMII interface

SGMII communication using the eTSEC is accomplished through the SerDes interface. See Table 15-1 for specific signal assignments.

# 15.9.3 Gigabit Ethernet controller channel operation

This section describes the operation of the eTSEC.

First, the software initialization sequence is described. Next, the software (Ethernet driver) interface for transmitting and receiving frames is reviewed. Frame filtering and receive filing algorithm features are also discussed. The section concludes with interrupt handling, inter-packet gap time, and loop back descriptions.

## 15.9.3.1 Initialization sequence

This section describes which registers are reset due to a hard or software reset and what registers the user must initialize prior to enabling the eTSEC.

#### 15.9.3.1.1 Hardware controlled initialization

A hard reset occurs when the system powers up.

All eTSEC registers and control logic are reset to their default states after a hard reset has occurred. In this state, each eTSEC behaves like a PowerQUICC III device, except for the absence of out-of-sequence TxBD features. That is, initially TCP/IP offload is disabled and only single RxBD and TxBD rings are accessible.

#### 15.9.3.1.2 User initialization

After the system has undergone a hard reset, software must initialize certain basic eTSEC registers.

Other registers can also be initialized during this time, but they are optional and must be determined based on the requirements of the system. See Table 15-3 for the register list. The following list describes the minimum steps for register initialization:

- 1. Set and clear MACCFG1 [Soft\_Reset]
- 2. Initialize MACCFG2
- 3. Initialize MAC station address
- 4. Set up the PHY using the MII management interface
- 5. Clear IEVENTGg
- 6. Initialize IMASKGg
- 7. Initialize RCTRL
- 8. Initialize DMACTRL

After the initialization of registers is performed, the user must execute the steps in the following order to bring the eTSEC into a functional state (out of reset):

1. Write to the MACCFG1 register and set the appropriate bits. These need to include RX\_EN and TX\_EN. To enable flow control, Rx\_Flow and Tx\_Flow should also be set.

- 2. For the transmission of Ethernet frames, TxBDs must first be built in memory, linked together as a ring, and pointed to by the TBASE*n* registers. A minimum of nine buffer descriptors per ring is required, unless the ring is disabled. If TCP/IP offload is to be enabled, the TxBD[TOE] bit must be set for each frame.
- 3. Likewise, for the reception of Ethernet frames, a minimum of nine buffer descriptors per ring is required, unless the ring is disabled, and the receive queue (or queues) must be ready, with its RxBD pointed to by the RBASE*n* registers. If TCP/IP offload is to be enabled, RCTRL[PRSDEP] must be set to the required offload level. Both transmit and receive can be gracefully stopped after transmission and reception begins.
- 4. Clearing DMACTRL[GTS] triggers the transmission of frame data if the transmitter had been previously stopped. The DMACTRL[GRS] must be cleared if the receiver had been previously stopped. Refer to the DMA control register (eTSEC\_DMACTRL) and Data buffer descriptors for more information.

## 15.9.3.2 Soft reset and reconfiguring procedure

Before issuing a soft-reset to and/or reconfiguring the MAC with new parameters, the user must properly shutdown the DMA and make sure it is in an idle state for the entire duration.

User must gracefully stop the DMA by setting both GRS and GTS bits in the DMACTRL register, then wait for both GRSC and GTSC bits to be set in the IEVENTGg register before resetting the MAC or changing parameters. Both GRS and GTS bits must be cleared before re-enabling the MAC to resume the DMA.

During the MAC configuration, if a new set of Tx buffer descriptors are used, the user must load the pointers into the TBASE registers. Likewise if a new set of Rx buffer descriptors are used, the RBASE registers must be written with new pointers.

The following procedure gracefully resets and reconfigures the MAC:

- 1. Set GRS/GTS bits in DMACTRL register.
- 2. Poll GRSC/GTSC bits in IEVENTGg register until both are set.
- 3. Set SOFT\_RESET bit in MACCFG1 register. (Note that SOFT\_RESET must remain set for at least 3 TX clocks before proceeding.)
- 4. Clear SOFT\_RESET bit in MACCFG1 register.
- 5. Load TBASE0-TBASE7 with new Tx BD pointers.
- 6. Load RBASE0-RBASE7 with new Rx BD pointers.
- 7. Setup other MAC registers (MACCFG2, MAXFRM, and so on).
- 8. Setup group address hash table (GADDR0-GADDR15) if address filtering is required.

- 9. Setup receive frame filer table (through RQFAR, RQFCR, and RQFPR) if filing to multiple RxBD rings is required.
- 10. Setup WWR, WOP, TOD bits in DMACTRL register.
- 11. Enable transmit queues in TQUEUE, and ensure that the transmit scheduling mode is correctly set in TCTRL.
- 12. Enable receive queues in RQUEUE, and optionally set TOE functionality in RCTRL.
- 13. Clear THLT and TXF bits in TSTATn registers by writing 1 to them.
- 14. Clear QHLT and RXF bits in RSTATn registers by writing 1 to them.
- 15. Clear GRS/GTS bits in DMACTRL. Do not change other bits.
- 16. Enable Tx\_EN/Rx\_EN in MACCFG1 register.

## 15.9.3.2.1 Timer soft reset and reconfiguring procedure

Software must do the following before asserting TMR\_CTRL[TMSR]:

- 1. Place the controller in graceful transmit stop (DMACTL[GTS]=1, wait for IEVENTGn[GTSC]=1).
- 2. Disable receive (MACCFG1[RX\_EN]=0)
  - After setting timer soft reset (TMR\_CTRL[TMSR]), software must leave the bit high for at least three 1588 reference clocks or tx\_clk cycles, whichever is slower, before clearing the bit.
- 3. Wait for TMR\_STAT[RCD] bit to be set before accessing any timer domain registers. Refer to Table 15-1074 and Table 15-1075.
- 4. Setup TMR\_CTRL register, including TCLK\_PERIOD and CKSEL (if update is desired).
- 5. Disarm the alarms with a write to TMR\_ALARM1\_L and TMR\_ALARM2\_L.
- 6. Clear alarm, periodic pulse, and external trigger event bits in TMR\_TEVENT.
- 7. Set up TMR\_TEMASK for desired interrupts.
- 8. Load TMR\_ADD with new value when in master mode and not in bypass mode (if update is desired).
- 9. Optionally update TMR\_FIPERn, and TMR\_PRSC.
- 10. Update TMR\_CNT\_H/L, and TMR\_OFF\_H/L to set the estimated PTP time (when in master mode).
- 11. Enable TMR\_CTRL[TE].
- 12. Enable attached Ethernet MAC's time stamping feature.

| 14016 15-1074. | Timer clock domain timer register list |
|----------------|----------------------------------------|
| ister name     | Description                            |

| Register name | Description                              |
|---------------|------------------------------------------|
| TMR_CNT_H/L   | Timer counter register                   |
| TMR_ADD       | Timer drift compensation addend register |
| TMR_ACC       | Timer accumulator register               |

Table continues on the next page...

Table 15-1074. Timer clock domain timer register list (continued)

| Register name  | Description                                    |
|----------------|------------------------------------------------|
| TMR_PRSC       | Timer prescale                                 |
| TMR_OFF_H/L    | Timer offset register                          |
| TMR_ALARM1_H/L | Timer alarm 1 register                         |
| TMR_ALARM2_H/L | Timer alarm 2 register                         |
| TMR_FIPER1     | Timer fixed period interval                    |
| TMR_FIPER2     | Timer fixed period interval                    |
| TMR_ETTS1_H/L  | Time stamp of general-purpose external trigger |
| TMR_ETTS2_H/L  | Time stamp of general-purpose external trigger |
| TMR_RXTS_H/L   | Receive time stamp register                    |
| TMR_TXTS1_H/L  | Transmit time stamp 1 register                 |
| TMR_TXTS2_H/L  | Transmit time stamp 2 register                 |

Table 15-1075. Platform clock (ipg\_clk) domain timer register list

| Register name | Description                      |
|---------------|----------------------------------|
| TMR_CTRL      | Timer control register           |
| TMR_PEVENT    | PTP packet event register        |
| TMR_PEMASK    | PTP packet event mask register   |
| TMR_TEVENT    | Time stamp event register        |
| TMR_TEMASK    | Timer event mask register        |
| TMR_STAT      | Timer status                     |
| TMR_TXTS1_ID  | Transmit time stamp ID1 register |
| TMR_TXTS2_ID  | Transmit time stamp ID2 register |

# 15.9.3.3 Gigabit Ethernet frame transmission

The Ethernet transmitter requires little core intervention.

After the software driver initializes the system, the eTSEC begins to poll the first transmit buffer descriptor (TxBD) in TxBD ring 0 every 512 transmit clocks. If TxBD[R] is set, and the TxBD ring is scheduled for transmission, the eTSEC begins copying the associated transmit buffer from memory to its Tx FIFO. The transmitter takes data from the Tx FIFO and transmits data to the MAC. The MAC transmits the data through the GMII interface to the physical media. The transmitter, once initialized, runs until the end-of-frame (EOF) condition is detected unless a collision within the collision window occurs (half-duplex mode) or an abort condition is encountered.

If the user has a frame ready to transmit, setting the DMACTRL[TOD] eliminates waiting for the next poll and a DMA transfer of the transmit data buffers can begin immediately. The transmission begins once all data for the frame is loaded into the Tx FIFO or sufficient transmit data (determined by the Tx FIFO threshold register) is in the Tx FIFO. If the line is not busy, the MAC transmit logic asserts TX\_EN and sends the 7-octet preamble sequence, 1-octet start of frame delimiter, and frame information in that order. If the line is busy, the controller waits for the carrier sense signal, CRS, to remain inactive for 60 bit times (60 clocks) and transmission begins after an additional 36 bit times (96 bit times after CRS became active). In full-duplex mode, because collisions are ignored, frame transmission maintains only the interframe gap (96 bit times) regardless of CRS.

In half-duplex mode (MACCFG2[Full Duplex] is cleared) the MAC defers transmission if the line is busy (CRS asserted). Before transmitting, the MAC waits for carrier sense to become inactive, at which point it then determines if CRS remains negated for 60 clocks. If so, transmission begins after an additional 36 bit times (96 bit times after CRS originally became negated). If CRS continues to be asserted, the MAC follows a specified back-off procedure and tries to retransmit the frame until the retry limit is reached. Data stored in the Tx FIFO is re-transmitted in case of a collision. This avoids unnecessary memory traffic.

The transmitter also monitors for an abort condition and terminates the current frame if an abort condition is encountered. In full-duplex mode the protocol is independent of network activity, and only the transmit inter-frame gap must be enforced.

The transmitter implements full-duplex flow control. If a flow control frame is received, the MAC does not service the transmitter's request to send data until the pause duration is over. If the MAC is currently sending data after a pause frame has been received and processed, the MAC finishes sending the current frame, then suspends subsequent frames (except a pause frame) until the pause duration is over. In addition, the transmitter supports transmission of flow control frames through TCTRL[TFC\_PAUSE]. The transmit pause frame is generated internally based on the PAUSE register that defines the pause value to be sent. Note that it is possible to send a pause frame while the pause timer has not expired.

The MAC automatically appends FCS (32-bit CRC) bytes to the frame if any of the following values are set:

- TxBD[PAD/CRC] is set in first TxBD
- TxBD[TC] is set in first TxBD
- MACCFG2[PAD/CRC] is set
- MACCFG2[CRC] is set

The Tx\_EN is negated after the FCS is sent. This notifies the PHY of the need to generate the illegal Manchester encoding that signifies the end of an Ethernet frame. Following the transmission of the FCS, the Ethernet controller writes the frame status bits into the BD and clears TxBD[R]. If the end of the current buffer is reached and TxBD[L] is cleared (a frame is comprised of multiple buffer descriptors), only TxBD[R] is cleared.

For both half- and full-duplex modes, an interrupt can be issued depending on TxBD[I]. The Ethernet controller then proceeds to the next TxBD in the table. In this way, the core can be interrupted after each frame, after each buffer, or after a specific buffer is sent. If TxBD[PAD/CRC] is set, the Ethernet controller pads any frame shorter than 64 bytes with zero bytes to make up the minimum length.

To pause transmission, or rearrange the transmit queue, set DMACTRL[GTS]. This can be useful for transmitting expedited data ahead of previously-linked buffers or for error situations. If this bit is set, the eTSEC transmitter performs a graceful transmit stop. The Ethernet controller stops immediately if no transmission is in progress or continues transmission until all queued frames in the Tx FIFO have been disposed of. The IEVENTGg[GTSC] interrupt occurs once the graceful transmit stop operation is completed. After the DMACTRL[GTS] is cleared, the eTSEC resumes transmission with the next frame.

While the eTSEC is in 10/100Mbps mode it sends bytes least-significant nibble first and each nibble is sent lsb first. While it is in 1000Mbps mode it sends bytes LSB first.

# 15.9.3.4 Gigabit Ethernet frame reception

The eTSEC Ethernet receiver is designed to work with little core intervention and can perform data extraction, address recognition, CRC checking, short frame checking, and maximum frame-length checking.

After a hardware reset, the software driver clears the RSTATn register(s) and sets MACCFG1[RX\_EN]. The Ethernet receiver is enabled and immediately starts processing receive frames. The MAC checks for when TSECn\_RX\_DV is asserted and as long as TSECn\_COL remains negated (full-duplex mode ignores TSECn\_COL), the MAC looks for the start of a frame by searching for a valid preamble/SFD (start of frame delimiter) header, which is stripped (unless MACCFG2[PreAM RxEN] is set) and the frame begins to be processed. If a valid header is not found, the frame is ignored.

If the receiver detects the first bytes of a frame, the eTSEC controller begins to perform the frame recognition function through destination address (DA) recognition (see Frame recognition). Based on this match the frame can be accepted or rejected. The receiver can filter frames based on individual (unicast), group (multicast), and broadcast addresses.

Because Ethernet receive frame data is not written to memory until the internal frame recognition algorithm is complete, system bus usage is not wasted on frames unwanted by this station.

If a frame is accepted, the Ethernet controller fetches the receive buffer descriptor (RxBD) from either queue 0 or the queue determined by the filer. If the RxBD is not being used by software (RxBD[E] is set), the eTSEC starts transferring the incoming frame. RxBD[F] is set for the first RxBD used for any particular receive frame. If the current RxBD is not available for the received frame, a receive busy error condition is raised in IEVENTGg[BSY].

After the buffer is filled, the eTSEC clears RxBD[E] and, if RxBD[I] is set, generates an interrupt. If the incoming frame is larger than the buffer, the Ethernet controller fetches the next RxBD in the table. If it is empty, the controller continues receiving the rest of the frame. In half-duplex mode, if a collision is detected during the frame, no RxBDs are used; thus, no collision frames are presented to the user except late collisions, which indicate LAN problems.

The RxBD length is determined by the MRBL field in the maximum receive buffer length register (MRBLR). The smallest valid value is 64 bytes, with larger values being be some integral multiple of 64 bytes. During reception, the Ethernet controller checks for frames that are too short or too long. After the frame ends (CRS is negated), the receive CRC field is checked and written to the data buffer. The data length written to the last RxBD in the Ethernet frame is the length of the entire frame, which enables the software to recognize an oversized frame condition.

Receive frames are not truncated when they exceed maximum frame bytes in the MAC's maximum frame register if MACCFG2[Huge Frame] is set, yet the babbling receiver error interrupt occurs (IEVENTGg[BABR] is set) and RxBD[LG] is set.

After the receive frame is complete, the Ethernet controller sets RxBD[L], updates the frame status bits in the RxBD, and clears RxBD[E]. If RxBD[I] is set, the Ethernet controller next generates an interrupt (that can be masked) indicating that a frame was received and is in memory. The Ethernet controller then waits for a new frame.

To interrupt reception or rearrange the receive queue, DMACTRL[GRS] must be set. If this bit is set, the eTSEC receiver performs a graceful receive stop. The Ethernet controller stops immediately if no frames are being received or continues receiving until the current frame either finishes or an error condition occurs. The IEVENTGg[GRSC] interrupt event is signaled after the graceful receive stop operation is completed. While in this mode the user can write to registers that are accessible to both the user and the eTSEC hardware without fear of conflict, and finally clear IEVENTGg[GRSC]. After

DMACTRL[GRS] is cleared, the eTSEC scans the input data stream for the start of a new frame (preamble sequence and start of frame delimiter), it resumes receiving, and the first valid frame received is placed in the next available RxBD.

## 15.9.3.5 Ethernet preamble customization

By default eTSEC generates a standard Ethernet preamble sequence prior to transmitting frames.

However, the user can substitute a custom preamble sequence for the purpose of controlling switching equipment at the receiver, particularly at 100/1000Mbps speeds. In any RMII mode only the standard preamble can be transmitted.

eTSEC normally searches for and discards the standard Ethernet preamble sequence upon receiving frames. Part of the received preamble sequence can be optionally recovered and returned as part of the frame data, making it visible to user software. Note that preamble cannot be recovered in any RMII mode.

Note that it is also possible for the first two bytes of custom preamble (PreOct0 and PreOct1) to be lost in during conversion to ten-bit code groups in the PCS sub-layer. Thus is it recommended that any custom preamble start at PreOct2.

## 15.9.3.5.1 User-defined preamble transmission

To substitute a custom preamble, the user must ensure the following:

- MACCFG2[PreAm TxEN] bit is set.
- The first TxBD of every frame containing a custom preamble has its PRE bit set.
- An 8-byte custom preamble sequence appears before the Ethernet DA field in the first transmit data buffer.

| Byte offsets | 0                   | 1       | 2 | 3 | 4 | 5 | 6 | 7       | 8                   | 9 | 10 | 11  | 12   | 13 | 14 | 15 |
|--------------|---------------------|---------|---|---|---|---|---|---------|---------------------|---|----|-----|------|----|----|----|
| 0-1          | 0-1 PreOct0 PreOct1 |         |   |   |   |   |   | PreOct0 |                     |   |    |     |      |    |    |    |
| 2-3          | PreOct2             |         |   |   |   |   |   |         | 2-3 PreOct2 PreOct3 |   |    |     |      |    |    |    |
| 4-5          |                     | PreOct4 |   |   |   |   |   |         |                     |   |    | Pre | Oct5 |    |    |    |
| 6-7          |                     | PreOct6 |   |   |   |   |   |         |                     |   |    |     |      |    |    |    |

Table 15-1076. Definition of custom preamble sequence

It should be noted that use of preamble octets matching the standard start of frame delimiter (0xD5) can be expected to trigger premature frame reception by the receiving station.

Table 15-1077. Custom preamble field descriptions

| Bytes | Bits | Name    | Description                                                                                                                                                            |
|-------|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1   | 0-7  | PreOct0 | Octet #0 of custom transmit preamble. This is the first octet of preamble sent.                                                                                        |
|       | 8-15 | PreOct1 | Octet #1 of custom transmit preamble. This is the second octet of preamble sent.                                                                                       |
| 2-3   | 0-7  | PreOct2 | Octet #2 of custom transmit preamble. This is the third octet of preamble sent.                                                                                        |
|       | 8-15 | PreOct3 | Octet #3 of custom transmit preamble. This is the fourth octet of preamble sent.                                                                                       |
| 4-5   | 0-7  | PreOct4 | Octet #4 of custom transmit preamble. This is the fifth octet of preamble sent.                                                                                        |
|       | 8-15 | PreOct5 | Octet #5 of custom transmit preamble. This is the sixth octet of preamble sent.                                                                                        |
| 6-7   | 0-7  | PreOct6 | Octet #6 of custom transmit preamble. This is the seventh octet of preamble sent. The last octet (the start of frame delimiter) is generated by the MAC automatically. |
|       | 8-15 | -       | Reserved; should be cleared.                                                                                                                                           |

### 15.9.3.5.2 User-visible preamble reception

To return the received preamble, the user must ensure the following:

- MACCFG2[PreAm RxEN] bit is set.
- Space for an 8-byte preamble sequence is allowed before the Ethernet DA field in the first receive data buffer of each frame.

Table 15-1078. Definition of received preamble sequence

| Byte<br>Offsets | 0               | 1       | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10      | 11  | 12   | 13 | 14 | 15 |
|-----------------|-----------------|---------|---|---|---|---|---|---|---|---|---------|-----|------|----|----|----|
| 0-1             | PreOct0 PreOct1 |         |   |   |   |   |   |   |   |   |         |     |      |    |    |    |
| 2-3             |                 | PreOct2 |   |   |   |   |   |   |   |   | PreOct3 |     |      |    |    |    |
| 4-5             |                 | PreOct4 |   |   |   |   |   |   |   |   |         | Pre | Oct5 |    |    |    |
| 6-7             |                 | PreOct6 |   |   |   |   |   |   |   |   |         |     |      |    |    |    |

Should the received preamble be shorter than the 7-octet sequence defined by IEEE Std. 802.3, initial bytes of the received preamble sequence hold undefined values. The standard start of frame delimiter (0xD5) is always omitted. Note that preamble extraction is not possible in RMII mode.

Table 15-1079. Received Preamble Field Descriptions

| Bytes | Bits | Name    | Description                                                                   |
|-------|------|---------|-------------------------------------------------------------------------------|
| 0-1   | 0-7  | PreOct0 | Octet #0 of received preamble. This is the first octet of preamble received.  |
|       | 8-15 | PreOct1 | Octet #1 of received preamble. This is the second octet of preamble received. |
| 2-3   | 0-7  | PreOct2 | Octet #2 of received preamble. This is the third octet of preamble received.  |
|       | 8-15 | PreOct3 | Octet #3 of received preamble. This is the fourth octet of preamble received. |

Table continues on the next page...

#### Table 15-1079. Received Preamble Field Descriptions (continued)

| Bytes | Bits | Name    | Description                                                                                                                               |  |  |
|-------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 4-5   | 0-7  | PreOct4 | Octet #4 of received preamble. This is the fifth octet of preamble received.                                                              |  |  |
|       | 8-15 | PreOct5 | Octet #5 of received preamble. This is the sixth octet of preamble received.                                                              |  |  |
| 6-7   | 0-7  | PreOct6 | Octet #6 of received preamble. This is the seventh octet of preamble received. The last octe (the start of frame delimiter) is discarded. |  |  |
|       | 8-15 | -       | Reserved                                                                                                                                  |  |  |

# **15.9.3.6 RMON support**

Using promiscuous mode, the eTSEC can automatically gather network statistics required for remote network interface monitoring.

The RMON MIB group 1, RMON MIB group 2, RMON MIB group 3, RMON MIB group 9, RMON MIB2, and the 802.3 Ethernet MIB are supported. For RMON statistics and their corresponding counters, see the memory map.

## 15.9.3.7 Frame recognition

The Ethernet controller performs frame recognition using destination address (DA) recognition.

A frame can be rejected or accepted based on the outcome.

# 15.9.3.7.1 Destination address recognition and frame filtering

The eTSEC can perform layer 2 frame filtering on the basis of destination Ethernet address (DA), as illustrated by the flowchart in the figure below.



Figure 15-1062. Ethernet address recognition flowchart

In promiscuous mode, the eTSEC accepts all received frames regardless of DA. Note, however, that Ethernet frame filtering simply restricts the traffic seen by the receive queue filer. Therefore even in promiscuous mode it remains possible to program the filer to reject frames based on their higher-layer header contents.

In the case of an individual address, the DA field of the received frame is compared with the physical address that the user programs in the station address registers (MACSTNADDR1 and MACSTNADDR2). If the DA does not match the station address, and exact MAC address matching is enabled through RCTRL[EMEN], the controller performs address recognition on the multiple MAC addresses written to the MACxADDR1 and MACxADDR2 registers. These virtual addresses give a particular eTSEC the ability to mirror other MACs on the network, which caters for router redundancy protocols, such as HSRP and VRRP.

If exact MAC address matching is not enabled, the eTSEC determines whether DA is a group or individual address. If DA is the standard broadcast address, and broadcast addresses are not rejected, the frame is accepted. If any other group address is received, the eTSEC looks-up the DA by means of the group hash table. The group hash table may be extended to 512 entries if RCTRL[GHTX] = 1. Otherwise, an individual address is hashed into the 256-entry individual hash table when RCTRL[GHTX] = 0.

# 15.9.3.7.2 Hash table algorithm

The hash table process used in the group hash filtering operates as follows.

By default, the Ethernet controller maps any 48-bit destination address into one of 256 bins, represented by the 256 bits in IGADDR0-IGADDR7 for individual addresses, and the 256 bits in GADDR0-GADDR7 for group addresses.

But in the case where RCTRL[GHTX] is set, both sets of registers are combined into an extended group-only hash table of 512 bits, where IGADDR0-IGADDR7 contain the first 256 bits and GADDR0-GADDR7 contain the last 256 bits. No individual-address table exists in extended mode.

The 48-bit destination address received by the MAC is passed through the Ethernet CRC-32 algorithm to produce a hash value. The CRC polynomial used is:

$$x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^{8} + x^{7} + x^{5} + x^{4} + x^{2} + x + 1$$

The MAC initializes its CRC register to 0xFFFF\_FFFF before computing a CRC on the 6 bit-reversed octets of the DA. A non-optimized sample of C code for computing the DA hash is listed in sample code below. The 9 most significant bits of the raw, uninverted CRC are used as the hash table index, H[8-0]. If RCTRL[GHTX] = 0, bits H[8-6] select one of the 8 IGADDR or GADDR registers, while bits H[5-1] select a bit within the 32-bit register. If RCTRL[GHTX] = 1, bits H[8-5] select one of the 16 registers in the {IGADDR, GADDR} set, while bits H[4-0] select a bit within the 32-bit register. For example, if H[8-5] = 7, IGADDR7 is selected, whereas H[8-5] = 9 selects GADDR1.

# Sample C Code for Computing eTSEC Hash Table Indices

```
/* Wrapper macros for 256-bucket and 512-bucket hash tables:
  Pass 6-byte Ethernet MAC address as parameter. */
#define TSEC_HASH256(macaddr) ((crc32(macaddr) >> 24) & 0xff)
#define TSEC_HASH512(macaddr) ((crc32(macaddr) >> 23) & 0x1ff)
/* CRC constants. Note: CRC-32 polynomial is bit-reversed. */
#define CRC_POLYNOMIAL 0xedb88320
#define CRC_INITIAL
                     0xffffffff
#define MAC ADDRLEN
#define BITS_PER_BYTE 8
/* crc32() Takes the array of bytes, macaddr[], representing an
  Ethernet MAC address and returns the CRC-32 result over these bytes,
  where each byte is used in bit-reversed form (Ethernet bit order).
  Index 0 of macaddr[] is the first byte of the address on the wire.
  Test case: the result of crc32 on {0x00, 0x01, 0x02, 0x03, 0x04, 0x05}
  should be 0xad0c28f3.
unsigned long crc32(unsigned char macaddr[MAC_ADDRLEN])
 unsigned long crc, result;
 int byte, i;
  /* CRC-32 algorithm starts by inverting first 4 bytes */
 crc = CRC INITIAL;
  /* add each byte to running CRC accumulator */
 for (byte = 0; byte < MAC_ADDRLEN; ++byte) {</pre>
   crc ^= macaddr[byte];
    /* shift CRC right to perform but reversal on byte of address */
    for (i = 0; i < BITS_PER_BYTE; ++i)
      if (crc & 1)
      crc = (crc >> 1) ^ CRC_POLYNOMIAL;
     else
      crc >>= 1;
  ^{\prime} /* finally, reverse bits of result to get CRC in normal bit order */
  for (result = 0, i = 4*BITS_PER_BYTE-1; i \ge 0; crc \ge 1, --i)
   result |= (crc & 1) << i;
 return result;
```

If the CRC hash table index selects a bit that is set in the hash table, the frame is accepted. If 32 group addresses are stored in the hash table and random group addresses are received, the extended hash table prevents roughly 480/512 (93.8%) of the group address frames from reaching memory. Software must further filter those that reach memory to determine if they contain the correct addresses. Alternatively, small multicast groups can be held in the exact match MAC address registers, which guarantees that only correct frames are admitted.

The effectiveness of the hash table declines as the number of addresses increases. For instance, as the number of addresses stored in the 512-bin hash table increases, the vast majority of the hash table bits are set, preventing only a small fraction of frames from reaching memory.

#### NOTE

The hash table cannot be used to reject frames that match a set of selected addresses because unintended addresses can map to the same bit in the hash table. The receive queue filer may be used to reject frames with unintended address hits in the hash table.

## 15.9.3.8 Magic Packet mode

eTSEC implements the AMD Magic Packet™ specification for LAN-initiated power management.

This mode is normally entered with the rest of the system in a low-power sleep mode. Software must enable normal receive function in the Ethernet MAC, and then finally set the MACCFG2[MPEN] bit to enable Magic Packet detection before the system enters a reduced mode. While the rest of the system is operating in low-power mode, the enabled eTSEC continues to receive Ethernet frames, but discards them immediately. Upon receipt of any frame whose contents contain the valid Magic Packet sequence, the eTSEC exits out of Magic Packet mode, thus clearing MACCFG2[MPEN], and raises an error/diagnostic interrupt through IEVENTGg[MAG], which causes the surrounding system to wake-up. Frames received after Magic Packet mode has exited are received into software buffers as usual. Software can abort Magic Packet mode by writing 0 to MACCFG2[MPEN] at any time.

AMD specify a Magic Packet<sup>TM</sup> to be any Ethernet frame containing a valid Ethernet header (Destination and Source Addresses) and valid FCS (CRC-32), and whose payload includes the specific Magic Packet byte sequence at any offset from the start of frame. The specific byte sequence comprises an unbroken stream of 102 bytes, the first 6 bytes of which are 0xFFFFF\_FFFFFF, followed by 16 copies of the MAC's unique IEEE station address in the normal byte order for Ethernet addresses. For example, if the station address were 0x112233\_445566, then the MAC would have to receive 0xFFFFFF\_FFFFFF, 0x112233\_445566, ..., 0x112233\_445566 in any payload to detect a Magic Packet. Only frames addressed specifically to the MAC's station address or a valid multicast or broadcast address can be examined for the Magic Packet sequence.

#### 15.9.3.9 Flow control

Because collisions cannot occur in full-duplex mode, gigabit Ethernet can operate at the maximum rate.

If the rate becomes too fast for a station's receiver, the station's transmitter can send flow-control frames to reduce the rate. Flow-control instructions are transferred by special frames of minimum frame size. The length/type fields of these frames have a special value.

| Size [Octets] | Description            | Value             | Comment                                                                                                                                                                                                      |
|---------------|------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | Preamble               | -                 | -                                                                                                                                                                                                            |
| 1             | SFD                    | -                 | Start frame delimiter                                                                                                                                                                                        |
| 6             | Destination address    | 01-80-C2-00-00-01 | Multicast address reserved for use in MAC frames                                                                                                                                                             |
|               |                        |                   | (or MAC station address)                                                                                                                                                                                     |
| 6             | Source address         | -                 | -                                                                                                                                                                                                            |
| 2             | Length/type            | 88-08             | Control frame type                                                                                                                                                                                           |
| 2             | MAC opcode             | 00-01             | Pause command                                                                                                                                                                                                |
| 2             | MAC parameter          | -                 | Pause time as defined by the PTV[PT] field. The pause period is measured in pause_quanta, a speed independent constant of 512 bit-times (unlike slot time). The most-significant octet is transmitted first. |
| 2             | Extended MAC parameter | -                 | Pause time extended as defined by the PTV[PTE] field. The most significant octet is transmitted first.                                                                                                       |
| 40            | Reserved               | -                 | -                                                                                                                                                                                                            |
| 4             | FCS                    | -                 | Frame check sequence (CRC)                                                                                                                                                                                   |

Table 15-1080. Flow control frame structure

If flow-control mode is enabled (MACCFG1[Rx\_Flow] is set) and the receiver identifies a pause-flow control frame, transmission stops for the time specified in the control frame. The controller completes any frame in progress before stopping transmission, and does not commence counting the pause time until transmit is idle. During a pause, only a control frame can be sent (TCTRL[TFC\_PAUSE] is set). Normal transmission resumes after the pause timer stops counting, or resumes immediately if a pause frame with a zero time-out is received. If another pause-control frame is received during the pause, the period changes to the new value received.

# 15.9.3.10 Grouping of rings

By default, eTSEC operates in 'single-group' mode, in which all events are mapped to a single group of interrupt lines (Rx, Tx, and error), and all memory-mapped register accesses to control ring behavior are done through a single 4 Kbyte region of memory.

A user may optionally map different Rx and Tx rings to different groups by setting the corresponding bits in the ISRGn registers ('multigroup mode'). These separate groups may then be mapped by software to different CPU cores, thus allowing load balancing of ethernet buffer descriptor management and interrupt handling across multiple CPUs on the device.

For example, a product with two CPU cores may elect to map eTSEC1 rings 0-3 to group 0 and rings 4-7 to group 1 by setting ISRG0 = 0xF0F0\_0000 and ISRG1 = 0x0F0F\_0000. CPU 0 could then be enabled to handle eTSEC1 group 0 by setting the destination of eTSEC1 group 0 Rx, Tx and error interrupts in the PIC to CPU 0, and by granting CPU 0 read/write access to the 4 Kbyte memory-mapped register region starting at 0xB\_0000. Similarly, CPU 1 could then be enabled to handle eTSEC1 group 1 by setting the destination of eTSEC1 group 1 Rx, Tx and error interrupts in the PIC to CPU 1, and by granting CPU 1 read/write access to the 4 Kbyte memory-mapped register region starting at 0xB\_4000.

Note that of the error and diagnostic interrupts, only BSY is associated with a ring. To enable full load-balancing of interrupt handling in multi-group mode, the non-ring-based error and diagnostic interrupts can be mapped to a group via the EMAPG and EMAPM registers.

In addition to interrupt routing and memory-mapped register addressing, multi-group mode also affects the behavior of Tx ring arbitration. See Transmission scheduling, for details.

## 15.9.3.11 Interrupt handling

The following describes what usually occurs within a eTSEC interrupt handler:

- 1. If an interrupt occurs, read IEVENTGg to determine interrupt sources. IEVENTGg bits to be handled in this interrupt handler are normally cleared at this time. There are three kinds of interrupts:
  - Errors (all bits in IEVENTGg other than RXB, RXF, TXB, or TXF)
  - Receive interrupts, when bits RXB or RXF in IEVENTGg are set
  - Transmit interrupts, when bits TXB or TXF in IEVENTGg are set
- 2. Process the TxBDs to reuse them if the IEVENTGg[TXB, TXF] were set. Consult register bits TSTATn[TXF0-TXF7] to determine which TxBD rings gave rise to the transmit interrupt in the case of TXF. If the transmit speed is fast or the interrupt delay is long, more than one transmit buffer may have been sent by the eTSEC; thus, it is important to check more than just one TxBD during the interrupt handler. One common practice is to process all TxBDs in the interrupt handler until one is found with R set.

- 3. Obtain data from RxBD rings if IEVENTGg[RXC, RXB or RXF] is set. Consult register bits RSTATn[RXF0-RXF7] to determine which RxBD rings gave rise to the receive interrupt in the case of RXF. If the receive speed is fast or the interrupt delay is long, the eTSEC may have received more than one RxBD; thus, it is important to check more than just one RxBD during interrupt handling. Typically, all RxBDs in the interrupt handler are processed until one is found with E set. Because the eTSEC pre-fetches BDs, the BD table must be big enough so that there is always another empty BD to pre-fetch, otherwise a BSY error occurs.
- 4. Clear any set halt or frame interrupt bits in TSTAT*n* and RSTAT*n* registers, or DMACTRL[GTS] and DMACTRL[GRS] by writing 1s to these bits.
- 5. Continue normal execution.

Table 15-1081. Non-error transmit interrupts

| Interrupt | Description                                                                                                                                 | Action taken by the eTSEC                                                                   |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| GTSC      | Graceful transmit stop complete: transmitter is put into a pause state after completion of the frame currently being transmitted.           | None                                                                                        |
| TXC       | Transmit control: Instead of the next transmit frame, a control frame was sent.                                                             | None                                                                                        |
| TXB       |                                                                                                                                             | Programmable 'write with response' TxBD to memory before setting IEVENTGg[TXB].             |
| TXF       | Transmit frame: A frame from an enabled TxBD ring was transmitted and the last transmit buffer descriptor (TxBD) of that frame was updated. | Programmable 'write with response' to memory on the last TxBD before setting IEVENTGg[TXF]. |

Table 15-1082. Non-error receive interrupts

| Interrupt | Description                                                                                                                                   | Action taken by the eTSEC                                                                   |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| GRSC      | Graceful receive stop complete: Receiver is put into a pause state after completion of the frame currently being received.                    | None                                                                                        |
| RXC       | Receive control: A control frame was received. As soon as the transmitter finishes sending the current frame, a pause operation is performed. | None                                                                                        |
| RXB       | Receive buffer: A receive buffer descriptor, that is not the last one of the frame, was updated in one of the enabled RxBD rings.             | Programmable 'write with response' RxBD to memory before setting IEVENTGg[RXB].             |
| RXF       | Receive frame: A frame was received to an enabled RxBD ring and the last receive buffer descriptor (RxBD) of that frame was updated.          | Programmable 'write with response' to memory on the last RxBD before setting IEVENTGg[RXF]. |

## 15.9.3.11.1 Interrupt coalescing

Interrupt coalescing offers the user the ability to contour the behavior of the eTSEC with regard to frame interrupts. Separate but identical mechanisms exist for both transmitted frames and received frames. In either case, frame interrupts require that software set the

I-bit in RxBDs or TxBDs, and disable buffer interrupts (IEVENTGg[RXB]) or IEVENTGg[TXB]). Particular rings can remain free of interrupts by ensuring that the I-bit is consistently cleared in all BDs. While interrupt coalescing is enabled, a transmit or receive frame interrupt is raised either when a counter threshold-defined number of frames is received/transmitted or the timer threshold-defined period of time has elapsed, whichever occurs first. Disabling and then re-enabling interrupt coalescing forces reset of the coalescing timers and counters to reflect changes made to the threshold registers.

### 15.9.3.11.2 Interrupt coalescing by frame count threshold

To avoid interrupt bandwidth congestion due to frequent, consecutive interrupts, the user may enable and configure interrupt coalescing to deliberately group frame interrupts, reducing the total number of interrupts raised. The number of frames received or transmitted prior to an interrupt being raised is determined by the frame threshold field (ICFT) in the appropriate interrupt coalescing configuration register (RXIC or TXIC). The frame threshold field may be assigned a value between 1 and 255. The internal transmit or receive frame counter decrements from this initial value each time a frame is transmitted or received. Upon reaching zero, an interrupt is raised, the appropriate threshold counter is reset to the value in the ICFT field, and then eTSEC continues counting frames while the interrupt is active. The appropriate threshold counter is also reset to the value in the ICFT field if an interrupt is raised subject to the corresponding threshold timer.

### 15.9.3.11.3 Interrupt coalescing by timer threshold

To avoid stale frame interrupts, the user may also assign a timer threshold, beyond which any frame interrupts not yet raised are forced.

The timer threshold fields of the receive and transmit interrupt coalescing configuration registers (RXIC[ICTT] and TXIC[ICTT]) are defined in units equivalent to 64 interface clocks or system clocks, depending on the setting of the ICCS field in RXIC and TXIC.

After transmitting a frame, the transmit interrupt coalescing threshold time begins counting down from the value in TXIC[ICTT]. An interrupt is raised when the counter reaches zero. In the event of graceful transmit stop completion before the coalescing timer expires, the eTSEC issues two interrupts, the first for GTS, the second for TXF (due to timer expiration of a pending event). To prevent the second interrupt from affecting servicing of the GTS event, it is recommended that the user mask out the TXF event during execution of the service routine.

After receiving a frame, the receive interrupt coalescing threshold time begins counting down from the value in RXIC[ICTT]. An interrupt is raised when the counter reaches zero. In the event of graceful receive stop completion before the coalescing timer expires,

the eTSEC issues two interrupts, the first for GRS, the second for RXF (due to timer expiration of a pending event). To prevent the second interrupt from affecting servicing of the GRS event, it is recommended that the user mask out the RXF event during execution of the service routine.

The interrupt coalescing timer thresholds (transmit and receive, operating independently) may be values ranging from 0x0001 to 0xFFFF. The table below specifies the range of possible timing thresholds subject to timer clock source, the interface or system frequency, and the value of the RXIC[ICTT] or TXIC[ICTT] field.

| ICCS (clock    | eTSEC interface format and          | Interrupt coalescing threshold time |                         |  |  |  |  |
|----------------|-------------------------------------|-------------------------------------|-------------------------|--|--|--|--|
| source)        | frequency or eTSEC system frequency | Minimum (ICTT = 0x0001)             | Maximum (ICTT = 0xFFFF) |  |  |  |  |
| 0 (I/F clock)  | 10Base-T at 2.5 MHz                 | 25.6 µs                             | 1.68 s                  |  |  |  |  |
| 0 (I/F clock)  | 100Base-T at 25 MHz                 | 2.56 µs                             | 168 ms                  |  |  |  |  |
| 0 (I/F clock)  | 1000Base-T at 125 MHz               | 0.51 µs                             | 33.6 ms                 |  |  |  |  |
| 1 (sys. clock) | eTSEC operating at 266 MHz          | 0.24 μs                             | 15.7 ms                 |  |  |  |  |
| 1 (sys. clock) | eTSEC operating at 333 MHz          | 0.19 µs                             | 12.6 ms                 |  |  |  |  |

Table 15-1083. Interrupt coalescing timing threshold ranges

The transmit timer threshold counter is reset to the value in TXIC[ICTT] and begins counting down on transmission of the frame following an interrupt.

The receive timer threshold counter is reset to the value in RXIC[ICTT] and begins counting down on receiving the frame following an interrupt.

### 15.9.3.12 Interframe gap time

If a station must transmit, it waits until the LAN becomes silent for a specified period (inter-frame gap, or IFG).

The minimum interpacket gap (IPG) time for back-to-back transmission is set by IPGIFG[Back-to-Back Interpacket-Gap]. The receiver receives back-to-back frames with the minimum interframe gap (IFG) as set in IPGIFG[Minimum IFG Enforcement]. If multiple frames are ready to transmit, the ethernet controller follows the minimum IPG as long as the following restrictions are met:

- The first TxBD pointer, TBPTRn, of any given frame is located at a 16-byte aligned address.
- Each TxBD[Data Length] is greater-than or equal to 64 bytes.

If the first TxBD alignment restriction is not met, the back-to-back IPG may be as many as 32 cycles. If the TxBD size restriction is not met, the back-to-back IPG may be significantly longer.

If a queue is actively transmitting, and multiple BDs are ready to transmit, the ethernet controller will satisfy the minimum IPG (96 bit times) as long as the following restrictions are met by software:

- The next BD is always ready when fetched by the controller.
- Frames use a single BD.
- TCP/UDP and IP Checksum generation are disabled in each frame's TxFCB, or in TCTRL, or frames are limited to 1200 bytes in length.
- Each TxBD[Data Length] ≥ 64 bytes.

If multiple BDs per frame are used, BD fetching may result in a gap between frames of up to 32 cycles if the fetch delay causes the amount of data in the TxFIFO to fall below the transmit threshold.

If TCP Offload is enabled (TCTRL[TUCSEN] = 1 or TCTRL[IPCSEN] = 1), the entire frame must be loaded in the TxFIFO before transmission can start. For frames longer than 1200 bytes, this delay in start of transmission can result in extra inter-packet gaps, with the delay increasing with size of frame.

In half-duplex mode, after a station begins sending, it continually checks for collisions on the LAN. If a collision is detected, the station forces a jam signal (all ones) on its frame and stops transmitting. Collisions usually occur close to the beginning of a packet. The station then waits a random time period (back-off) before attempting to send again. After the back-off completes, the station waits for silence on the LAN (carrier sense negated) and then begins retransmission (retry) on the LAN. Retransmission begins 36 bit times after carrier sense is negated for at least 60 bit times. If the frame is not successfully sent within a specified number of retries, an error is indicated (collision retry limit exceeded).

# 15.9.3.13 Internal and external loop back

Setting MACCFG1[Loop Back] causes the MAC transmit outputs to be looped back to the MAC receive inputs.

Clearing this bit results in normal operation. This bit is cleared by default. Clearing this bit results in normal operation.

# 15.9.3.14 Error-handling procedure

The eTSEC reports frame reception and transmission error conditions using the channel BDs, the error counters, and the IEVENTGg registers.

Table 15-1084. Transmission errors

| Error                                 | Response                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter underrun                  | Transmitter underrun can occur either after frame transmission has commenced, or in response to an incomplete sequence of TxBDs. In the former case, the controller sends 32 bits that ensure a CRC error, and terminates buffer transmission. In the latter case, all transmit queues are halted (TSTAT[THLTx] are set). In all cases, the eTSEC closes the buffer, sets TxBD[UN], IEVENTGg[XFUN]. The controller resumes transmission after TSTATn[THLTm] is cleared (and DMACTRL[GTS] is cleared and TQUEUE[ENm] is enabled.) |
| Retransmission attempts limit expired | The controller terminates buffer transmission, sets TxBD[RL], closes the buffer, and sets IEVENTGg[CRL]. All transmit queues are halted (TSTAT[THLTx] are set). Transmission resumes after TSTATn[THLTm] is cleared (and DMACTRL[GTS] is cleared and TQUEUE[ENm] is enabled))                                                                                                                                                                                                                                                    |
| Late collision                        | The controller terminates buffer transmission, sets TxBD[LC], closes the buffer, and sets IEVENTGg[LC]. All transmit queues are halted (TSTAT[THLTx] are set). The controller resumes transmission after TSTATn[THLTm] is cleared (and DMACTRL[GTS] is cleared and TQUEUE[ENm] is enabled).                                                                                                                                                                                                                                      |
| Memory read error                     | A system bus error occurred during a DMA transaction. The controller sets IEVENTGg[EBERR], DMA stops sending data to the FIFO which causes an underrun error, and therefore TxBD[UN] is set, but IEVENTGg[XFUN] is not set. All transmit queues are halted (TSTAT[THLTx] are set). Transmits are continued once TSTATn[THLTm] is cleared (and DMACTRL[GTS] is cleared and TQUEUE[ENm] is enabled.)                                                                                                                               |
| Data parity error                     | Data in the transmit FIFO was potentially corrupted. The controller sets IEVENTGg[DPE], but otherwise continues transmission until halted explicitly.                                                                                                                                                                                                                                                                                                                                                                            |
| Babbling transmit error               | A frame is transmitted which exceeds the MAC's Maximum Frame Length and MACCFG2[Huge Frame] is a 0. The controller sets IEVENTG <i>gn</i> [BABT] and continues without interruption.                                                                                                                                                                                                                                                                                                                                             |

### Table 15-1085. Reception errors

| Error                              | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Overrun error                      | The Ethernet controller maintains an internal FIFO buffer for receiving data. If a receiver FIFO buffer overrun occurs, the controller sets RxBD[OV], sets RxBD[L], closes the buffer, increments the discarded frame counter (RDRP), and sets IEVENTGg[RXF], The receiver then enters hunt mode (seeking start of a new frame).                                            |
| Busy error                         | A frame is received and discarded due to a lack of buffers. The controller sets IEVENTGg[BSY] and increments the discarded frame counter (RDRP). In addition, the RSTATn[QHLTm] bit is set. RDRP increments for each frame that is received while the receiver is halted due to a busy condition. The halted queue resumes reception once the RSTATn[QHLTm] bit is cleared. |
| Filed frame to invalid queue error | A frame is received and discarded as a result of the filer directing it to an RxBD ring that is currently not enabled. The controller sets IEVENTGg[FIQ] and increments the discarded frame counter (RDRP).                                                                                                                                                                 |

## Table 15-1085. Reception errors (continued)

| Error                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Parser error                     | If the receive frame parser is enabled, a parse error can be flagged as a result of inconsistencies discovered between fields of the embedded packet headers. For example, the L2 header may indicate an IPv4 header, but the IP version number fails to match. In the event of a parse error, parsing is terminated at the inconsistent header, and the RxFCB[PERR] field indicates at which layer of the protocol stack the error was discovered. Receiver function continues regardless of parse errors, but IEVENTGg[PERR] is set. The receive queue filer may operate with reduced or default information in some cases; therefore, filer rule sets should be constructed so as to be tolerant of misformed frames.                                                                                                                                                                        |  |  |  |  |  |
|                                  | Below is a complete list of conditions that will cause a parse error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                                  | <ul> <li>Version error in ipv4 or ipv6 header for non-tunnel case (ie transitioning from L2 to L3 header). Version field in ipv4 header is not 4. Version field in ipv6 header is not 6. Only apply to non-FIFO mode.</li> <li>Version error in ipv4 or ipv6 header for tunnel cases. For example, a packet may have multiple L3 headers and logic is transitioning from one L3 header to the next L3 header. Version field in ipv4 header is not 4. Version field in ipv6 header is not 6. Apply to all modes.</li> <li>Rx FIFO overflow. Apply to all modes (FIFO and non-FIFO)</li> <li>Truncated rx frame without receiving an ipv4 or ipv6 header. Apply to all modes.</li> <li>ipv4 header's IHL error if &lt; 5. Apply to all modes.</li> <li>ARP's HLN fields not equal to 0x06. Apply to all modes.</li> <li>ARP's PLN field not equal to 0x04 or 0x10. Apply to all modes.</li> </ul> |  |  |  |  |  |
|                                  | <b>Note:</b> Any values in the length/type field between 1500 and 1536 is treated as a length, however, only illegal packets exist with this length/type since these are not valid lengths and not valid types. These are treated by the MAC logic as out of range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                  | Software must confirm the parser and filer results by checking the type/length field after the packet has been written to memory to see if it falls in this range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| Ethernet framing error           | With L2 parser mode enable, an Ethernet framing error can be flagged as a result of receiving a bad L2 header. The filer can detect an Ethernet framing error via PID1's EER bit. No further parsing on the frame will be done if an Ethernet framing error is detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|                                  | Below is a complete list of conditions that will cause an Ethernet framing error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                                  | <ul> <li>Shim header &gt; 14 and frame does not have DA. For example, the frame is terminated before DA is received.</li> <li>Shim header &gt; 8 and frame does not have SA. For example, the frame is terminated before SA is received.</li> <li>Shim header &gt; 6 and frame does not have Type/Length. For example, the frame is terminated before Type/Length is received.</li> <li>Frame with PPOE's version ≠ 0x11.</li> <li>Frame with valid type received by no more data after type (i.e frame is terminated early).</li> </ul>                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| Non-octet error (dribbling bits) | The Ethernet controller handles a nibble of dribbling bits if the receive frame terminates as non-octet aligned and it checks the CRC of the frame on the last octet boundary. If there is a CRC error, the frame non-octet aligned (RxBD[NO]) error is reported, IEVENTGg[RXF] is set, and the alignment error counter increments. The eTSEC relies on the statistics collector block to increment the receive alignment error counter (RALN). If there is no CRC error, no error is reported.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| CRC error                        | If a CRC error occurs, the controller sets RxBD[CR], closes the buffer, and sets IEVENTGg[RXF]. This eTSEC relies on the statistics collector block to record the event. After receiving a frame with a CRC error, the receiver then enters hunt mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| Memory read error                | A system bus error occurred during a DMA transaction. The controller sets IEVENTGg[EBERR] and discards the frame and increments the discarded frame counter (RDRP). In addition the RSTATn[QHLTm] bit is set. The halted queue resumes reception once the RSTATn[QHLTm] bit is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |

### Table 15-1085. Reception errors (continued)

| Error | Description                                                                                                                                                      |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Data in the receive FIFO or filer table was potentially corrupted. The controller sets IEVENTGg[DPE], but otherwise continues reception until halted explicitly. |
|       | A frame is received that exceeds the MAC's maximum frame length. The controller sets IEVENTGg[BABR] and continues.                                               |

### 15.9.4 TCP/IP offload

Each eTSEC provides hardware support for accelerating the basic functions of TCP/IP packet transmission and reception. By default, these features are disabled and must be explicitly enabled through RCTRL and TCTRL.

In this configuration, the eTSEC processes frames as vanilla Ethernet frames and none of the multi-ring QoS/CoS receive services or per-frame VLAN insertion and deletion are available. Operate eTSEC in this default configuration when using existing TCP/IP stack software that has not been modified to take advantage of TOE.

TOE can be enabled independently for Rx and Tx and at various levels. Receive TOE functions are controlled by RCTRL and transmit functions through a combination of TCTRL[TUCSEN] and the Tx frame control block.

On receive, according to RCTRL[PRSDEP], eTSEC can parse frames at layer 2 of the stack only (Ethernet headers and switching headers), layers 2 to 3 (including IPv4 or IPv6), or layers 2 to 4 (including TCP and UDP). TOE provides protocol header recognition, header verification (IPv4 header checksum verification), and TCP/UDP payload checksum verification including verification of associated pseudo-header checksums. For large frames offload of checksum verification saves a significant fraction of the CPU cycles that would otherwise be spent by the TCP/IP stack. IP packet fragmentation and re-assembly, and TCP stream establishment and tear-down are not performed in hardware. The frame parser sets RQFPR[IPF] status flag encountering a fragmented frame. The frame parser in eTSEC searches a maximum of 512 bytes from the start of a received frame when attempting to locate headers; headers deeper than 512 bytes are assumed not to exist, and any associated receive status flags in the frame control block remain cleared.

On transmit, TOE provides IPv4 and TCP/UDP header checksum generation. Like receive TOE, checksum generation reduces CPU load significantly for TCP/IP stacks modified to exploit eTSEC TOE functions. The eTSEC does not checksum transmitted packets with IPv6 routing headers or calculate TCP/UDP checksums from IP fragments. If a transmitted TCP segment requires checksum generation but IPv6 extension headers

would prevent eTSEC from calculating the pseudoheader checksum, software can calculate just the pseudoheader checksum in advance and supply it to the eTSEC as part of per-frame TOE configuration.

#### 15.9.4.1 Frame control blocks

Frame control blocks (FCBs) are 8-byte blocks of TOE control and/or status data that are passed between software (driver and TCP/IP stack) and each eTSEC.

A FCB always precedes the frame it applies to, and is present only when TOE functions are being used. The first BD of each frame points to the initial data buffer and the FCB. The initial data buffer must be at least 8 bytes long to contain the FCB without breaking it. Custom or received Ethernet preamble sequences also follow the FCB if preambles are visible.



Figure 15-1063. Location of frame control blocks for TOE parameters

For TxBD rings, FCBs are assumed present when the TxBD[TOE/UN] bit is set by user software. The eTSEC ignores the TxBD[TOE/UN] bit in all BDs other than those pointing to initial data buffers, therefore FCBs must not be inserted in second and subsequent data buffers. Since TxBD[TOE/UN] can be set under software discretion, TOE acceleration for transmit may be applied on a frame-by-frame basis.

In the case of RxBD rings, FCBs are inserted by the eTSEC whenever RCTRL[PRSDEP] is set to a non-zero value. Only one FCB is inserted per frame, in the buffer pointed to by the RxBD with bit F set. TOE acceleration for receive is enabled for all frames in this case.

### 15.9.4.2 Transmit path off-load and Tx PTP packet parsing

TOE functions for transmit are defined by the contents of the Tx FCB.

Table 15-1086. Transmit frame control block

|            | 0   | 1     | 2   | 3   | 4   | 5   | 6   | 7   | 8 | 9    | 10 | 11 | 12 | 13 | 14  | 15 |
|------------|-----|-------|-----|-----|-----|-----|-----|-----|---|------|----|----|----|----|-----|----|
| Offset + 0 | VLN | ΙP    | IP6 | TUP | UDP | CIP | CTU | NPH | P |      |    |    |    |    | PTP |    |
| Offset + 2 |     | L4OS  |     |     |     |     |     |     |   | L3OS |    |    |    |    |     |    |
| Offset + 4 |     | PHCS  |     |     |     |     |     |     |   |      |    |    |    |    |     |    |
| Offset + 6 |     | VLCTL |     |     |     |     |     |     |   |      |    |    |    |    |     |    |

The user instructs the Tx packet to be time stamped via setting bit 15 in the TxFCB to mark a PTP packet. TxFCB[VLCTL] can be translated as the Tx PTP packet identification number. BD[TOE] has to be set to enable transmit PTP packet time stamping. TxFCB[PTP] bit takes precedence over TxFCB[VLN] bit. It disables per packet VLAN tag insertion. On a PTP packet, VLAN tag can be inserted from the DFVLAN register.

Table 15-1087. Tx frame control block description

| Bytes | Bits | Name | Description                                                                                                                                             |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1   | 0    | VLN  | VLAN control word valid. This bit is ignored when the PTP bit is set. VLAN tag is read from the DFVLAN register if PTP = 1.                             |
|       |      |      | 0 Ignore VLCTL field.                                                                                                                                   |
|       |      |      | 1 If VLAN tag insertion is enabled for eTSEC, use the VLCTL field as the VLAN control word.                                                             |
|       | 1    | IP   | Layer 3 header is an IP header.                                                                                                                         |
|       |      |      | 0 Ignore layer 3 and higher headers.                                                                                                                    |
|       |      |      | 1 Assume that the layer 3 header is an IPv4 or IPv6 header, and take L3OS field as valid.                                                               |
|       | 2    | IP6  | IP header is IP version 6. Valid only if IP = 1.                                                                                                        |
|       |      |      | 0 IP header version is 4.                                                                                                                               |
|       |      |      | 1 IP header version is 6.                                                                                                                               |
|       | 3    | TUP  | Layer 4 header is a TCP or UDP header.                                                                                                                  |
|       |      |      | 0 Do not process any layer 4 header.                                                                                                                    |
|       |      |      | 1 Assume that the layer 4 header is either TCP or UDP (see UDP bit), and offload checksumming on the basis that the IP header has no extension headers. |
|       | 4    | UDP  | UDP protocol at layer 4.                                                                                                                                |
|       |      |      | 0 Layer 4 protocol is either TCP (if TUP = 1) or undefined.                                                                                             |
|       |      |      | 1 Layer 4 protocol is UDP if TUP = 1.                                                                                                                   |

# Table 15-1087. Tx frame control block description (continued)

| Bytes | Bits   | Name   | Description                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|-------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0-1   | 5      | CIP    | Checksum IP header enable.                                                                                                                                                                                                                                                   |  |  |  |  |  |
|       |        |        | 0 Do not generate an IP header checksum.                                                                                                                                                                                                                                     |  |  |  |  |  |
|       |        |        | 1 Generate an IPv4 header checksum.                                                                                                                                                                                                                                          |  |  |  |  |  |
|       | 6      | CTU    | Checksum TCP or UDP header enable.                                                                                                                                                                                                                                           |  |  |  |  |  |
|       |        |        | 0 Do not generate a TCP or UDP header checksum. RFC 768 advises that UDP packets not requiring checksum validation should have their checksum field set to zero.                                                                                                             |  |  |  |  |  |
|       |        |        | 1 Generate a TCP header checksum if IP = 1 and TUP = 1 and UDP = 0.                                                                                                                                                                                                          |  |  |  |  |  |
|       | 7      | NPH    | Disable calculation of TCP or UDP pseudoheader checksum. This bit should be set if IP options need to be consulted in forming the pseudoheader checksum, as eTSEC does not examine IP options or extension headers for TCP/IP offload on transmit.                           |  |  |  |  |  |
|       |        |        | 0 Calculate TCP or UDP pseudo-header checksum as normal, assuming that the IP header has no options.                                                                                                                                                                         |  |  |  |  |  |
|       |        |        | 1 Do not calculate a TCP or UDP pseudo-header checksum, but instead use the value in field PHCS when determining the overall TCP or UDP checksum.                                                                                                                            |  |  |  |  |  |
|       | 8-14   | -      | Reserved                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|       | 15 PTP |        | Indication to the transmitter that this is a PTP packet. Enabling PTP disables per packet VLAN tag insertion. Instead, VLAN tag will be read from the DFVLAN when the PTP field is true.                                                                                     |  |  |  |  |  |
|       |        |        | 0 Do not attempt to capture transmission event time                                                                                                                                                                                                                          |  |  |  |  |  |
|       |        |        | 1 Valid PTP_ID field. When this packet is transmitted, capture the time of transmission.                                                                                                                                                                                     |  |  |  |  |  |
|       |        |        | Must be clear if TMR_CTRL[TE] is clear.                                                                                                                                                                                                                                      |  |  |  |  |  |
| 2-3   | 0-7    | L4OS   | Layer 4 header offset from start of layer 3 header. The layer 4 header starts L4OS octets after the layer 3 header if it is present. The maximum layer 3 header length supported is thus 255 bytes, which may prevent TCP/IP offload on particularly large IPv6 headers.     |  |  |  |  |  |
|       | 8-15   | L3OS   | Layer 3 header offset from start of frame not including the 8 bytes for this FCB. The layer 3 header starts L3OS octets from the start of the frame including any custom preamble header that may be present. The maximum layer 2 header length supported is thus 255 bytes. |  |  |  |  |  |
| 4-5   | 0-15   | PHCS   | Pseudo-header checksum (16-bit one's complement sum with carry wraparound, but without result inversion) for TCP or UDP packets, calculated by software. Valid only if NPH = 1.                                                                                              |  |  |  |  |  |
| 6-7   | 0-15   | VLCTL  | VLAN control word for insertion in the transmitted VLAN tag. Valid only if VLN = 1.                                                                                                                                                                                          |  |  |  |  |  |
|       |        | /      | Tx PTP packet identification number. This number will be copied into the Tx PTP                                                                                                                                                                                              |  |  |  |  |  |
|       |        | PTP_ID | packet time stamp identification field. PTP field takes precedence over VLN field.                                                                                                                                                                                           |  |  |  |  |  |

# 15.9.4.3 Receive path offload

Upon receive, the Rx FCB returns the status of frame parse and TOE functions applied to the accompanying frame.

Table 15-1088. Receive frame control block

|            | 0   | 1             | 2   | 3   | 4   | 5   | 6   | 7   | 8              | 9 | 10 | 11           | 12 | 13 | 14 | 15   |
|------------|-----|---------------|-----|-----|-----|-----|-----|-----|----------------|---|----|--------------|----|----|----|------|
| Offset + 0 | VLN | IP            | IP6 | TUP | CIP | CTU | EIP | ETU |                | - |    | HASH<br>_VAL | PE | RR | -  | GPFP |
| Offset + 2 | -   |               | RQ  |     |     |     |     |     | PRO            |   |    |              |    |    |    |      |
| Offset + 4 |     | FLR_HASH[0:7] |     |     |     |     |     |     | FLR_HASH[8:15] |   |    |              |    |    |    |      |
| Offset + 6 |     | VLCTL         |     |     |     |     |     |     |                |   |    |              |    |    |    |      |

Table 15-1089. Rx frame control block descriptions

| Bytes | Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1   | 0    | VLN  | VLAN tag recognized. This bit is set only if RCTRL[VLEX] is set.                                                                                                                                                                                                                                                                                                       |
|       |      |      | 0 No VLAN tag recognized.                                                                                                                                                                                                                                                                                                                                              |
|       |      |      | 1 IEEE Std. 802.1Q VLAN tag found; VLAN control word in VLCTL is valid.                                                                                                                                                                                                                                                                                                |
|       | 1    | IP   | IP header found at layer 3.RCTRL[PRSDEP] must be set to 10 or 11 in order to enable IP discovery. See also IP6 bit of FCB.                                                                                                                                                                                                                                             |
|       |      |      | 0 No layer 3 header recognized.                                                                                                                                                                                                                                                                                                                                        |
|       |      |      | 1 An IP header was recognized at layer 3; the IANA protocol identifier for the next header can be found in PRO; see PRO for more information.                                                                                                                                                                                                                          |
|       |      |      | If software is relying on the RxFCB for the parse results, any RxFCB[IP] bits set with the corresponding RxFCB[PRO] = 0xFF indicates a fragmented packet (or that this packet had a back-to-back IPv6 routing extension header). Additionally, RQFPR[IPF] (see Receive queue filing table property register * (eTSEC_RQFPR)) indicates that the packet was fragmented. |
|       | 2    | IP6  | IP version 6 header found at layer 3.                                                                                                                                                                                                                                                                                                                                  |
|       |      |      | 0 No IPv6 header was found.                                                                                                                                                                                                                                                                                                                                            |
|       |      |      | 1 The layer 3 header was an IPv6 header provided IP = 1.                                                                                                                                                                                                                                                                                                               |
|       | 3    | TUP  | TCP or UDP header found at layer 4. RCTRL[PRSDEP] must be set to 10 or 11 in order to enable TCP/UDP discovery.                                                                                                                                                                                                                                                        |
|       |      |      | 0 No layer 4 header recognized.                                                                                                                                                                                                                                                                                                                                        |
|       |      |      | 1 The layer 4 header was recognized as either TCP (PRO = 0x06) or UDP (PRO = 0x11).                                                                                                                                                                                                                                                                                    |
|       | 4    | CIP  | IPv4 header checksum checked. RCTRL[PRSDEP] must be set to 10 or 11 in order to enable IPv4 checksum verification.                                                                                                                                                                                                                                                     |
|       |      |      | 0 IPv4 header checksum not verified, either because verification was disabled or a valid IPv4 header could not be located.                                                                                                                                                                                                                                             |
|       |      |      | 1 IPv4 header checksum was verified by the eTSEC, and bit EIP indicates result.                                                                                                                                                                                                                                                                                        |

# Table 15-1089. Rx frame control block descriptions (continued)

| Bytes | Bits  | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 5     | CTU       | TCP or UDP header checksum checked. RCTRL[PRSDEP] must be set to 11 in order to enable layer 4 checksum verification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |       |           | 0 TCP or UDP header checksum not verified, either because verification was disabled or a valid TCP or UDP header could not be located. If a UDP header with zero checksum was located, this bit is cleared in accordance with RFC 768.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |       |           | 1 TCP or UDP header checksum was verified by the eTSEC, and ETU indicates result.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | 6     | EIP       | IPv4 header checksum verification error. Not valid unless CIP = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |       |           | 0 No checksum error in IPv4 header.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |       |           | 1 Error in header checksum only if IP = 1 and IP6 = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0-1   | 7     | ETU       | TCP or UDP header checksum verification error. Not valid unless CTU = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |       |           | 0 No checksum error in TCP or UDP header.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |       |           | 1 Error in header checksum only if PRO = 0x06 or PRO = 0x11.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | 8-10  | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 11    | HASH_ VAL | FLR_HASH value is valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 12-13 | PERR      | Parse error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |       |           | 00 No error in L2 to L4 parse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |       |           | 01 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |       |           | 10 Inconsistent or unsupported L3 header sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |       |           | 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | 14    | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 15    | GPFP      | General-purpose filer event packet. This packet was filed based on matching a GPI rule sequence.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2-3   | 0-1   | -         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 2-7   | RQ        | Receive queue index. This index was selected by the eTSEC Rx Filer (from a matching Filer rule's RQCTRL[Q] field) when it accepted the associated frame. If filing is not enabled, RQ is zero. Note that the 3 least significant bits of RQ correspond with the RxBD ring index whenever RCTRL[FSQEN] = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 8-15  | PRO       | If IP = 1, PRO is set as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |       |           | <ul> <li>PRO = 0xFF for a fragment header or a back-to-back route header</li> <li>PRO = 0xnn for an unrecognized header, where nn is the next protocol field</li> <li>PRO = TCP/UDP header, as defined in the IANA specification, if TCP or UDP header is found</li> <li>If IP = 0, PRO is undefined.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |       |           | Note that the eTSEC parser logic stops further parsing when encountering an IP datagram that has indicated that it has fragmented the upper layer protocol. This in general means that there is likely no layer 4 header following the IP header and extension headers. eTSEC leaves the RxFCB[PRO] and RQFPR[L4P] fields 0xFF in this case, which usually means that there was no IP header seen. In this case RxFCB[IP] and optionally RxFCB[IP6] is set. IP header checksumming operates and performs as intended. Most of the time, the eTSEC updates the RxFCB[PRO] field and RQFPR[L4P] fileds with whatever value was found in the protocol field of the IP header. See Receive queue filing table property register * (eTSEC_RQFPR), for a description of RQFPR. |

Table 15-1089. Rx frame control block descriptions (continued)

| Bytes | Bits | Name           | Description                                                                                                                                                            |
|-------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4-5   | 0-7  | FLR_HASH[0:7]  | Upper 8 bits of 16-bit filer hash value (not valid unless HASH_VAL is 1). Note that this 16-bit hash value is extracted from upper 16 bit of 32-bit filer hash result. |
|       | 8-15 | FLR_HASH[8:15] | Lower 8 bits of 16-bit filer hash value (not valid unless HASH_VAL is 1). Note that this 16-bit hash value is extracted from upper 16 bit of 32-bit filer hash result. |
| 6-7   | 0-15 | VLCTL          | VLAN control word as per IEEE Std. 802.1Q. The lower 12 bits comprise the VLAN identifier. Valid only if VLN = 1.                                                      |

## 15.9.5 Quality of service (QoS) provision

This section describes the quality of service support features of this device.

It includes a parser which extracts vital packet properties and passes then to the filer which essentially acts as a frame classifier.

### 15.9.5.1 Receive parser

The receive parser parses the incoming frame data and generates filer properties and frame control block (FCB).

The receive parser composes of the Ethernet header parser and L3/L4 parser.

The Ethernet header parser parses only L2 (ethertype) headers. It is enabled by  $RCTRL[PRSDEP] \neq 0$ . It has the following key features:

- Extraction of 48-bit MAC destination and source addresses
- Extraction and recognition of the first 2-byte ethertype field
- Extraction and recognition of the final 2-byte ethertype field
- Extraction of 2-byte VLAN control field
- Walk through MPLS stack and find layer 3 protocol
- Walk through VLAN stack and find layer 3 protocol
- Recognition of the following ethertypes for inner layer parsing
  - LLC and SNAP header
  - JUMBO and SNAP header
  - IPV4
  - IPV6
  - VLAN
  - MPLSU/MPLSM
  - PPPOES

For stack L2 (that is, more than one ethertypes) header, the Ethernet parser traverses through the header until it finds the last valid ethertype or the ethertype is unsupported. Below is a description of what the Ethernet header parser recognizes for stack L2 header.

The L3 parser is enabled by RCTRL[PRSDEP] = 10 or 11. It begins when the Ethernet parser ends and a valid IPv4/v6 ethertype is found. The L4 header is enabled by RCTRL[PRSDEP] = 11. It begins when the L3 parser ends and a valid TCP/UDP next protocol is found and no fragment frame is found. The primary functionalities of L3(IPv4/6) and L4(TCP/UDP) parsers are as follows:

- IP recognition (v4/v6, encapsulated protocol)
- IP header checksum verification
- IPv4/6 over IPv4/6 (tunneling)-parse headers and find layer 4 protocol
- IP layer 4 protocol/next header extraction
- Stop parsing on unrecognized next header/protocol
- IPv4 support
  - IPv4 source and destination addresses
  - 8-bit IPv4 type of service
  - IP layer 4 protocol/next header support
    - IPV4
    - IPV4 Fragment. Parser stops after a fragment is found
    - TCP/UDP
- IPv6 support
  - The first 4 bytes of the IPv6 source address extraction
  - The first 4 bytes of the IPv6 destination address extraction
  - IPv6 source address hash for pseudo header calculation
  - IPv6 destination address hash for pseudo header calculation
  - 8-bit IPv6 traffic class field extraction
  - Payload length field extraction
  - IP layer 4 protocol/next header support
    - IPV6
    - IPV6 fragment. Parser stops after a fragment is found
    - IPV6 route
    - IPV6 hop/destination
    - TCP/UDP
- L4 (TCP/UDP) support
  - Extraction of 16-bit source port number extraction
  - Extraction of 16-bit destination port number extraction
  - TCP checksum calculation (including pseudo header)
  - UDP checksum calculation if the checksum field is not zero (including pseudo header)

### 15.9.5.2 Receive queue filer

The receive queue filer receives protocol header properties extracted from the incoming frame by the eTSEC frame parse engine.

A property is defined to be a field extracted from a packet header, such as a TCP port number or VLAN identifier. As soon as the last identifiable header has been recognized, the filer commences searching the receive queue filer table, comparing properties in the table against properties extracted from the frame. Software populates the table with property values, stored to the RQPROP field, and indicates how to match and interpret the properties by setting flags in the RQCTRL field. The eTSEC memory map provides access to these fields by way of an address register (RQFAR) and two porthole registers (RQFCR and RQFPR).



Figure 15-1064. Structure of the receive queue filer table

### 15.9.5.2.1 Filing rules

Unless the filer is disabled, every received frame from the Ethernet MAC initiates a search of the receive queue filer table, starting at entry 0.

The table search is terminated as soon as an entry is found whose contents match a property of the frame. Accordingly, software must guarantee that at least one entry results in a match-even if only to set a default receive queue index.

Since eTSEC searches the table at a rate of two entries every system clock cycle, all 256 entries can be searched in the time taken to receive a 64-byte Ethernet frame.

The equation to calculate the maximum rules is  $MaxRules = (sysclk/phyclk) \times 2 \times (TF + IFG)$  where:

- sysclk = eTSEC clock frequency
- phyclk = clock frequency of physical interface
- TF = number of PHY clocks between start of one frame and when the parser is finished with parsing the frame.
- IFG = interframe gap

For example, sysclk = 333 MHz, PHY clk = 155 MHz, a 40-byte packet in 16-bit FIFO mode results in  $(333 \div 155)$  x  $((40 \text{ bytes} \div (16 \text{ bits x } (1 \text{ byte} \div 8 \text{ bits})) + 3)$  x 2, or 98 rules. Note that in this 40-byte example, the number of rules calculated (e.g. 98) is valid only if the parser does not stop before 40 bytes of frame data is received. It is recommended for the filer to have additional rules to filter out frames that the parser stops parsing before 40 bytes of frame data is received. Note that in non-FIFO modes such as GMII running at slow platform frequence, MaxRules equation will also apply. For example, using 20 for IPG, a minimum of 190.5 MHz eTSEC sysclk (381 MHz platform) is needed to process all 256 entries in GMII for a 64B receive frame.

Each entry of the receive queue filer table specifies a simple match rule for determining how to process the received frame. The elements of a filing rule, expressed in the RQCTRL and RQPROP fields, are summarized as follows:

- The PID field in RQCTRL identifies what property is being matched against RQPROP. The eTSEC supports 16 properties, some of which are different portions of the same header field. Reserved or unused bits in RQPROP are read as zero. See Receive queue filing table property register \* (eTSEC\_RQFPR) for a list of all properties and their associated PID values.
- The Q field in RQCTRL identifies which one of 64 virtual receive queues the frame should be filed to (sent through DMA) in the event of a filing rule match that accepts the frame. The physical RxBD ring this queue maps to is controlled by the RCTRL[FSQEN] bit. If RCTRL[FSQEN] = 0, the three least significant bits of the Q field indicate which physical RxBD ring hosts the queue. If RCTRL[FSQEN] = 1, RxBD ring 0 hosts all receive queues, but the RxFCB[RQ] field allows software to distinguish queues by ID. In all cases if Q maps to a RxBD ring that is not currently enabled, the frame is discarded with an IEVENTGg[FIQ] error.
- The REJ field in RQCTRL controls whether the frame is to be rejected (REJ = 1) or filed (REJ = 0) upon a filing rule match. Rejected frames occupy Rx FIFO space, but do not consume memory bus cycles.
- The CMP field in RQCTRL determines how property PID is compared against RQPROP. Equality, inequality, greater-or-equal, and less-than compares are available.

- The AND field in RQCTRL allows more than one comparison in a sequence to be chained together as a Boolean AND condition. Setting AND = 1 defers evaluation of the rule until the next entry has been matched, which may, in turn, have AND set. If any comparison involving AND = 1 fails, the entire chained sequence fails. A typical use for AND is to combine a pair of comparisons in a range match; the first such entry has AND = 1, the second has AND = 0 and its values of Q and REJ take effect.
- The CLE field in RQCTRL offers a way to bracket a set of consecutive-perhaps related-rules into a rule cluster. A cluster must be preceded by a guard rule, which simply determines whether the cluster rules can be evaluated. If the guard rule succeeds and its last entry has both CLE = 1 and AND = 1, the cluster rules that follow are enabled. The cluster ends at the first entry where CLE = 1 and AND = 0, which may also belong to a rule that files or rejects a frame. If the guard rule fails, all rules in the cluster are skipped, including mask\_register assignments. Clusters must not be nested.
- The GPI field offers the user the ability to interrupt the core upon matching a rule that causes a frame to be filed to memory. Once the last RxBD corresponding to that frame is written to memory, the IEVENTGg[FGPI] event will be asserted. This bit will be set regardless of any interrupt coalescing that may be set.

### 15.9.5.2.2 Comparing properties with bit masks

By default, extracted properties are compared arithmetically according to the CMP field in each RQCTRL word.

This permits point value matches in each table entry, and range checks across a pair of table entries combined with the AND attribute in RQCTRL. However, inspection of the parse flags, Ethernet preamble, and IP addresses typically requires 'don't care' bit fields in the properties to be cleared as part of the comparison. The eTSEC provides a dedicated 32-bit register, known as the mask\_register, for performing such masking operations. At the start of each table search by the filer, mask\_register is reset to 0xFFFF\_FFFF, which ensures that no masking occurs.

Filer rules may be configured to assign specific bit patterns to mask\_register. Such rules can be configured to either match always (useful for implementing a default rule and specifying an associated receive queue), or fail always (which prevents termination of the filer table search). Once mask\_register has been assigned, it retains its value until it is reassigned or the table search terminates. All properties are non-destructively bit-wise ANDed with mask\_register prior to comparison in subsequent rules, which allows an entire cluster of rules to make use of a common mask. Individual masks for specific rules can also be created simply by combining a mask\_register assignment (match always form) with a regular rule using the AND attribute.

To create a mask\_register assignment rule, it is necessary to select PID = 0 in RQCTRL, and choose CMP such that the rule either matches (CMP = 01) or fails (CMP = 11). In this entry, RQPROP is then considered to be the assigned bit vector.

When AND chain, cluster or compound rule fails, mask value rolls back to mask value prior to failing AND chain, cluster, or compound rule. Compound rule is defined as AND chain followed by cluster or AND chain inside cluster.

### 15.9.5.2.3 Special-case rules

It is frequently useful to create rules that are guaranteed to succeed or fail, specifically to enforce a default filing decision or act as null entries.

| Table 15-1090. | Special | filer | rules |
|----------------|---------|-------|-------|
|----------------|---------|-------|-------|

| Rule Description                         |     |      | F   | RQCTR | L Fields |     |      | RQPROP      | RQCTRL               |  |
|------------------------------------------|-----|------|-----|-------|----------|-----|------|-------------|----------------------|--|
|                                          | GPI | CLE  | REJ | AND   | Q        | СМР | PID  | Word        | Word <sup>1</sup>    |  |
| Default file-Always file frame to ring Q | 0   | 0    | 0   | 0     | Q        | 01  | 0000 | All zeros   | 0x0000_ <i>qq</i> 20 |  |
| Default reject-Always discard frame      | 0   | 0    | 1   | 0     | 000_000  | 01  | 0000 | All zeros   | 0x0000_0120          |  |
| Empty rule in AND-Always matches         | 0   | 0/12 | 0   | 1     | 000_000  | 01  | 0000 | 0xFFFF_FFFF | 0x0000_00A0          |  |
| Empty rule in rule set-Always fails      | 0   | 0/13 | 0   | 0     | 000_000  | 11  | 0000 | 0xFFFF_FFFF | 0x0000_0060          |  |

- 1. Hexadecimal digits qq denotes field Q shifted left 2 bits.
- 2. Set CLE = 1 if the empty rule guards a cluster.
- 3. Set CLE = 1 if the empty rule occurs at the end of a cluster.

### 15.9.5.2.4 Filer hash engine

IPv6 SA/DA parse results are hashed into 32-bit data each.

If rule matches with hash bit of 1 and PID is 1100(DIA) or 1101 (SIA), and IPv6 header is recognized by parser, DIA and SIA hashed results are used instead of 32 MSB DIA/SIA in filer hash engine. Note that 32 MSB DIA/SIA are still used to match PID 1100 and PID 1101, respectively. When RQCTRL[HASH] bit is set and rule is matched, unmasked property of this specific entry is hashed with ORD hash function through filer hash engine. One exception: RQCTRL[HASH] has to be 0 for set mask rule (PID 0000). The upper 16 bits of the filer hash result is written into FCB byte 4 and byte 5. The lower 3 bits of the upper 16 bit hash result is used in ring index mapping logic.



Figure 15-1065. Hash engine

### 15.9.5.2.5 Ring index mapping logic

Different fields of RIR's are selected through mapping logic, which is illustrated below.

Note that the 3-bit counter is a round-robin counter, which increments when frames are filed and not rejected.



Figure 15-1066. Ring index mapping logic

### 15.9.5.2.6 Hash function

Hash function relies on a mathematical function that we have called 'ORD'.

ORD takes two parameters that specify shift amounts. ORD(i,j) operates on the implied operand of the internal state of the hash s and is defined as follows:

ORD(i,j) sets the new internal state  $s' = s \land (s < i) \land ((s < j \mid s < (i+j)))$ 

Negative values for i and j designate a right-shift instead of left-shift.

The ORD function was derived from noticing that adds provide good avalanche/diffusion properties, but are too slow for a silicon implementation (around four or more cascaded adds are required every cycle). ORD is related to a half-adder equation, but has a few changes that increase diffusion.

The following code shows the 32-bit ORD hash function used to hash IPv6 SA/DA and filer property.

```
combine(input block b) {
s = s ^ b;}
mix() {
s = ORD(1,6);
s = ORD(-14,-3);
s = Rotate(s,11);}
postmix() {
mix();
mix();
mix();}
```

### 15.9.5.2.7 Filer interrupt events

The filer can produce three interrupt events in IEVENTGg.

Event FIR indicates an error condition where the filer was unable to provide a definite result, either because no rule in the table succeeded, or because frames arrived too rapidly to complete searching of the table. Event FIQ indicates that the filer accepted a frame to a RxBD ring that was not enabled in RQCTRL (this can also occur if the filer is disabled, but RxBD ring 0-default queue or FSQEN mode queue-is not enabled). FIQ is also asserted in the case where no rule in the entire table succeeded. The various combinations of these interrupt events and their interpretation appear in the table below.

| IEVENTGg<br>[FIR] | IEVENTGg<br>[FIQ] | Description                                                                                                               |
|-------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------|
| 0                 | 0                 | No error. The filer successfully rejected or filed a frame.                                                               |
| 0                 | 1                 | Illegal queue error. The filer accepted a frame to a RxBD ring that is disabled (including ring 0 if filing is disabled). |
| 1                 | 0                 | Partial search error. The filer did not have sufficient time to complete its search of the filer table.                   |
| 1                 | 1                 | No matching rule error. The filer searched all 256 entries of the filer table without finding a rule that succeeds.       |

Table 15-1091. Receive queue filer interrupt events

A functional interrupt is provided via use of the general purpose interrupt (GPI) bit in the filer table. When a property matches the value in the RQPROP entry at this index, and REJ = 0 and AND = 0, the filer will set IEVENTGg[FGPI] when the corresponding receive frame is written to memory. This allows the user to set up a filer rule where the core will be interrupted upon the reception of 'special' frames.

If the timer is enabled (TMR\_CTRL[TE] = 1), then the interrupt dedicated for timer events (in addition to the usual receive, transmit and error interrupts) will be asserted.

### 15.9.5.2.8 Setting up the receive queue filer table

The eTSEC frame parser always provides values for all properties, even where the relevant headers are not available.

In the latter case, the filer is given default properties that can be used to avoid conflict with normal, defined property values. Accordingly, the rules in the filer table can be partitioned into rule sets such that if all rules in a given set fail (due to headers being unavailable), lower priority rule sets can be subsequently searched until either a rule set provides a match or a single default-catch-all-rule specifies a definite receive queue. For example, an 802.1p priority rule set may be followed by an IP TOS rule set, followed by a default rule; thus, if no VLAN tag appears in the received frame, the TOS rules are checked, or the default is activated should no IP header be present.

The rule cluster feature is used to conditionalize evaluation of rule sets. Typically, this avoids evaluating rules based on properties that may not be valid or relevant to the filing or filtering decision. For example, TCP-related rules might be clustered behind a guard rule that checks that a TCP header has appeared and the IP address matches our home address. Property 1-the parse flags property-is provided specifically to check the characteristics of the received frame and the parser error status. The mask\_register is typically assigned beforehand to extract specific flags, in which case care should be taken that mask\_register be reassigned an appropriate mask vector for following comparisons.

In many cases it is possible to write the entire filer table before using eTSEC, as the rule set is static. However, dynamic rule updates can be supported by pre-allocating partially instantiated rule sets, which software rewrites as necessary. Rules that are not instantiated should be composed of empty entries, as indicated in Table 15-1090. In many cases empty entries can be overwritten by software without stopping eTSEC's receive function.

### 15.9.5.2.9 Filer example-802.1p priority filing

This example illustrates how to file frames according to layer 2 802.1p priority.

This matches against property 1001, comparing each specific priority level in order to associate them with a RxBD ring index. Note that if a VLAN tag does not appear in the frame, the parser passes priority 0 to the filer, which always matches the rule at entry 7 and terminate the table search.

| Table |     |      |     | RQCI | TRL fiel | ds      |     |      | RQPROP      | Comment                                                                     | RQCTRL      |
|-------|-----|------|-----|------|----------|---------|-----|------|-------------|-----------------------------------------------------------------------------|-------------|
| entry | GPI | HASH | CLE | REJ  | AND      | Q       | СМР | PID  |             |                                                                             | word        |
| 0     | 0   | 0    | 0   | 0    | 0        | 000_000 | 00  | 1001 | 0x0000_0007 | File priority 7 to ring 0                                                   | 0x0000_0009 |
| 1     | 0   | 0    | 0   | 0    | 0        | 000_001 | 00  | 1001 | 0x0000_0006 | File priority 6 to ring 1                                                   | 0x0000_0409 |
| 2     | 0   | 0    | 0   | 0    | 0        | 000_010 | 00  | 1001 | 0x0000_0005 | File priority 5 to ring 2                                                   | 0x0000_0809 |
| 3     | 0   | 0    | 0   | 0    | 0        | 000_011 | 00  | 1001 | 0x0000_0004 | File priority 4 to ring 3                                                   | 0x0000_0C09 |
| 4     | 0   | 0    | 0   | 0    | 0        | 000_100 | 00  | 1001 | 0x0000_0003 | File priority 3 to ring 4                                                   | 0x0000_1009 |
| 5     | 0   | 0    | 0   | 0    | 0        | 000_101 | 00  | 1001 | 0x0000_0002 | File priority 2 to ring 5                                                   | 0x0000_1409 |
| 6     | 0   | 0    | 0   | 0    | 0        | 000_110 | 00  | 1001 | 0x0000_0001 | File priority 1 to ring 6                                                   | 0x0000_1809 |
| 7     | 0   | 0    | 0   | 0    | 0        | 000_111 | 00  | 1001 | All zeros   | File undefined 802.1p<br>or priority 0 to ring 7-<br>Default always matches | 0x0000_1C09 |

Table 15-1092. Filer table example-802.1p priority filing

### 15.9.5.2.10 Filer example-IP diff-serv code points filing

This example demonstrates use of rule priority for determining class selector codepoints (RFC 2474) from the IP TOS property.

An example filer table is shown in the table below . The example relies on the fact that the first rule matched terminates the search, hence successively lower Diff-Serv codepoint ranges can be compared in each step until the default (zero or greater) range is reached. By default, property 1010 (IP TOS) takes the value 0x00 if no IP headers were recognized, therefore the table search always terminates.

|       |     | iabi | C 13- | 1033 | . 1110  | i table | CXAIII | pic-ii | uiii-seiv t | oue points ming                       |             |
|-------|-----|------|-------|------|---------|---------|--------|--------|-------------|---------------------------------------|-------------|
| Table |     |      |       | RQCT | RL Fiel | ds      |        |        | RQPROP      | Comment                               | RQCTRL      |
| Entry | GPI | HASH | CLE   | REJ  | AND     | Q       | СМР    | PID    |             |                                       | Word        |
| 0     | 0   | 0    | 0     | 0    | 0       | 001_000 | 01     | 1010   | 0x0000_00E0 | File class 7 to queue 8 (TOS ≥ 0xE0)  | 0x0000_202A |
| 1     | 0   | 0    | 0     | 0    | 0       | 001_001 | 01     | 1010   | 0x0000_00C0 | File class 6 to queue 9 (TOS ≥ 0xC0)  | 0x0000_242A |
| 2     | 0   | 0    | 0     | 0    | 0       | 001_010 | 01     | 1010   | 0x0000_00A0 | File class 5 to queue 10 (TOS ≥ 0xA0) | 0x0000_282A |
| 3     | 0   | 0    | 0     | 0    | 0       | 001_011 | 01     | 1010   | 0x0000_0080 | File class 4 to queue 11 (TOS ≥ 0x80) | 0x0000_2C2A |
| 4     | 0   | 0    | 0     | 0    | 0       | 000_100 | 01     | 1010   | 0x0000_0060 | File class 3 to queue 4 (TOS ≥ 0x60)  | 0x0000_102A |

Table 15-1093. Filer table example-IP diff-serv code points filing

Table 15-1093. Filer table example-IP diff-serv code points filing (continued)

| Table |     |      |     | RQCT | RL Fiel | ds      |     |      | RQPROP      | Comment                                                                 | RQCTRL      |
|-------|-----|------|-----|------|---------|---------|-----|------|-------------|-------------------------------------------------------------------------|-------------|
| Entry | GPI | HASH | CLE | REJ  | AND     | Q       | CMP | PID  |             |                                                                         | Word        |
| 5     | 0   | 0    | 0   | 0    | 0       | 001_100 | 01  | 1010 | 0x0000_0040 | File class 2 to queue 12 (TOS ≥ 0x40)                                   | 0x0000_302A |
| 6     | 0   | 0    | 0   | 0    | 0       | 010_100 | 01  | 1010 | 0x0000_0020 | File class 1 to queue 20 (TOS ≥ 0x20)                                   | 0x0000_502A |
| 7     | 0   | 0    | 0   | 0    | 0       | 011_100 | 01  | 1010 | All zeros   | File class 0 to queue 28 (TOS $\geq$ 0x00) or file to ring 4 by default | 0x0000_702A |

## 15.9.5.2.11 Filer example-TCP and UDP port filing

This example demonstrates rule clusters and AND-combined entries for filing packets based on transport protocol and well-known port numbers in a termination application.

An example filer table is shown in the table below . The example contains two clusters; the first is entered only for TCP packets, the second is entered only for UDP packets. A default filing rule catches the case where neither TCP nor UDP headers are found. Each cluster compares source port number (property 1111) against a list of server ports, and files the packets accordingly. Note that entries 1 and 2 form an AND rule for checking that the port number  $\geq 20$  and port number < 22. Entries 4 and 5 are initially set up to always fail (zero port number), and thus comprise empty entries that can be used at a later time.

Table 15-1094. Filer table example-TCP and UDP port filing

| Table |     |      |     | RQC | TRL fiel | ds      |     |      | RQPROP      | Comment                                     | RQCTRL      |
|-------|-----|------|-----|-----|----------|---------|-----|------|-------------|---------------------------------------------|-------------|
| entry | GPI | HASH | CLE | REJ | AND      | Q       | СМР | PID  |             |                                             | word        |
| 0     | 0   | 0    | 1   | 0   | 1        | 000_000 | 00  | 1011 | 0x0000_0006 | Enter cluster if layer 4 is TCP             | 0x0000_028B |
| 1     | 0   | 0    | 0   | 0   | 1        | 000_000 | 01  | 1111 | 0x0000_0014 | AND rule-FTP from                           | 0x0000_00AF |
| 2     | 0   | 0    | 0   | 0   | 0        | 000_010 | 11  | 1111 | 0x0000_0016 | TCP ports 20 and 21:<br>file to ring 2      | 0x0000_086F |
| 3     | 0   | 0    | 0   | 0   | 0        | 000_011 | 00  | 1111 | 0x0000_0017 | Telnet from TCP port 23: file to ring 3     | 0x0000_0C0F |
| 4     | 0   | 0    | 0   | 0   | 0        | 000_000 | 00  | 1111 | All zeros   | empty entry reserved for future use         | 0x0000_000F |
| 5     | 0   | 0    | 0   | 0   | 0        | 000_000 | 00  | 1111 | All zeros   | empty entry reserved for future use         | 0x0000_000F |
| 6     | 0   | 0    | 1   | 0   | 0        | 000_001 | 01  | 0000 | All zeros   | end cluster; default<br>TCP: file to ring 1 | 0x0000_0620 |
| 7     | 0   | 0    | 1   | 0   | 1        | 000_000 | 00  | 1011 | 0x0000_0011 | Enter cluster if layer 4 is UDP             | 0x0000_028B |

Table 15-1094. Filer table example-TCP and UDP port filing (continued)

| Table |     |      |     | RQC | TRL fiel | ds      |     |      | RQPROP      | Comment                                  | RQCTRL      |
|-------|-----|------|-----|-----|----------|---------|-----|------|-------------|------------------------------------------|-------------|
| entry | GPI | HASH | CLE | REJ | AND      | Q       | СМР | PID  |             |                                          | word        |
| 8     | 0   | 0    | 0   | 0   | 0        | 000_101 | 00  | 1111 | 0x0000_0801 | NFS from UDP port<br>2049                | 0x0000_140F |
| 9     | 0   | 0    | 0   | 0   | 0        | 000_111 | 00  | 1111 | 0x0000_0208 | Route from UDP port 520                  | 0x0000_000F |
| 10    | 0   | 0    | 0   | 0   | 0        | 000_110 | 00  | 1111 | 0x0000_0045 | TFTP from UDP port 69                    | 0x0000_180F |
| 11    | 0   | 0    | 1   | 0   | 0        | 000_100 | 01  | 0000 | All zeros   | End cluster; default UDP: file to ring 4 | 0x0000_1220 |
| 12    | 0   | 0    | 0   | 0   | 0        | 000_000 | 01  | 0000 | All zeros   | By default, file to ring 0               | 0x0000_0020 |

### 15.9.5.2.12 Filer example-hash on AND chain (2-tuple)

The example in Table 15-1095demonstrates hashing protocol on AND chain entries with 2-tuple, SA, DA.

It is based on following rules.

- Corresponding parser property is hashed if current rule entry is matched and HASH bit is set.
- Corresponding parser property is not hashed if current rule entry is matched and HASH bit is not set
- AND chain fail would cause hash value being reset back to the value that is before start of AND chain.

Table 15-1095. Filer example-hash on AND chain (2-tuple)

| Table |     |      |     | RQCT | RL field | s |     |      | RQPROP      | Comment                                                                                                           |
|-------|-----|------|-----|------|----------|---|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------|
| entry | GPI | Hash | CLE | REJ  | AND      | Q | СМР | PID  |             |                                                                                                                   |
| 0     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1100 | 0xC0A8_0000 | Compare DIA to 192.168.x.x (via previous mask instruction). If match add DIA to accumulated hash else reset hash. |
| 1     | 0   | 0    | 0   | 0    | 1        | Х | 01  | 0000 | 0xFFFF_FFFF | Set mask, no hash operation since hash bit is 0.                                                                  |
| 2     | 0   | 1    | 0   | 0    | 0        | X | 00  | 1101 | 0x0A0A_0A0A | Compare SIA to 10.10.10.10. If match add SIA to accumulated hash else reset hash.                                 |

## 15.9.5.2.13 Filer example-hash on AND chain (3-tuple)

The example in the table below demonstrates hashing protocol on AND chain entries with 3-tuple, SA, DA, and layer 4 protocol.

Table 15-1096. Filer example-hash on AND chain (3-tuple)

| Table |     |      |     | RQCTI | RL Field | s |     |      | RQPROP      | Comment                                                                                                                                  |
|-------|-----|------|-----|-------|----------|---|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Entry | GPI | Hash | CLE | REJ   | AND      | Q | СМР | PID  |             |                                                                                                                                          |
| 0     | 0   | 1    | 0   | 0     | 1        | Х | 00  | 1100 | 0xC0A8_0000 | Compare DIA to 192.168.x.x (via previous mask instruction). If match add DIA to accumulated hash else reset hash.                        |
| 1     | 0   | 0    | 0   | 0     | 1        | Х | 01  | 0000 | 0xFFFF_FFFF | Set mask, no hash operation since hash bit is 0.                                                                                         |
| 2     | 0   | 1    | 0   | 0     | 1        | Х | 00  | 1101 | 0x0A0A_0A0A | Compare SIA to 10.10.10.10. If match add SIA to accumulated hash else reset hash.                                                        |
| 3     | 0   | 0    | 0   | 0     | 0        | Х | 00  | 1011 | 0x0000_0011 | Match if I4 protocol is UDP, does not get hashed no matter if it matches or not since hash bit is 0; hash value gets reset if not match. |

### 15.9.5.2.14 Filer example-hash on AND chain (5-tuple)

The example in the table below demonstrates hashing protocol on AND chain entries with 5-tuple, SA, DA, and layer 4 protocol, SPT, DPT.

Table 15-1097. Filer example-hash on AND chain (5-tuple)

| Table |     |      |     | RQCT | RL field | s |     | RQPROP | Comment     |                                                                                                                                          |
|-------|-----|------|-----|------|----------|---|-----|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| entry | GPI | Hash | CLE | REJ  | AND      | Q | СМР | PID    |             |                                                                                                                                          |
| 0     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1100   | 0xC0A8_0000 | Compare DIA to 192.168.x.x (via previous mask instruction). If match add DIA to accumulated hash else reset hash.                        |
| 1     | 0   | 0    | 0   | 0    | 1        | Х | 01  | 0000   | 0xFFFF_FFFF | Set mask, no hash operation since hash bit is 0.                                                                                         |
| 2     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1101   | 0x0A0A_0A0A | Compare SIA to 10.10.10.10. If match add SIA to accumulated hash else reset hash.                                                        |
| 3     | 0   | 0    | 0   | 0    | 1        | Х | 00  | 1011   | 0x0000_0011 | Match if I4 protocol is UDP, does not get hashed no matter if it matches or not since hash bit is 0; hash value gets reset if not match. |
| 4     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1111   | 0x0000_0505 | Compare SPT with 0x0505. Hash SPT if matches else reset hash.                                                                            |
| 5     | 0   | 1    | 0   | 0    | 0        | Х | 00  | 1110   | 0x0000_0A0A | Compare DPT with 0x0A0A. Hash DPT if matches else reset hash.                                                                            |

### 15.9.5.2.15 Filer example-hash on cluster rules

The example in the table below demonstrates hashing protocol on cluster rules.

It is based on the following rules:

- Corresponding parser property is hashed if current rule entry is matched and HASH bit is set.
- Corresponding parser property is not hashed if current rule entry is not matched or HASH bit is not set.
- Cluster exit without a match would cause hash value being reset back to hash seed value 0xFFFF FFFF.
- A 2-entry cluster where the cluster entry is immediately followed by cluster exit is not supported. Since a 2-entry AND chain and a 2-entry cluster are logic equivalent, an AND chain should be used if needed.

Table **RQCTRL Fields RQPROP** Comment entry GPI CLE REJ AND PID Hash **CMP** Х 0 0 1 0 1 00 1100 0xC0A8\_0000 Cluster Guard rule. Compare DIA to 192.168.x.x (via previous mask instruction). If match enter cluster and add DIA to accumulated hash else reset hash. 1 0 0 0 Χ 0000 0xFFFF\_FFFF 0 01 Set mask, no hash operation since hash bit is 0. 2 0 Χ 0 0 0 00 1101 0x0A0A\_0A0A Compare SIA to 10.10.10.10. If match add SIA to accumulated hash else not hashed. 0 Х 1011 0x0000\_0011 Cluster exit rule. Match if I4 protocol is 3 0 UDP, does not get hashed no matter if it matches or not since hash bit is 0; hash value gets reset if cluster exists without a match.

Table 15-1098. Filer example-hash on cluster rules

## 15.9.5.2.16 Filer example-hash on compound rule

The example in the table below shows how hash value is accumulated in a compound rule.

In this example, compound starts from an AND chain, followed by cluster guard rule, then a cluster with an embedded AND chain. Note that hash value is either reset to hash seed or hash value after guard rule depending location of the specific entry in compound rule.

Table 15-1099. Filer example-hash on compound rule

| Table |     |      |     | RQCT | RL field | s |     | RQPROP | Comment     |                                                                                                                                                                                                                        |
|-------|-----|------|-----|------|----------|---|-----|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| entry | GPI | Hash | CLE | REJ  | AND      | Q | СМР | PID    |             |                                                                                                                                                                                                                        |
| 0     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1100   | 0xC0A8_0000 | Compare DIA to 192.168.x.x (via previous mask instruction). If match add DIA to accumulated hash else reset hash back to hash value before this entry, which is the same as hash seed.                                 |
| 1     | 0   | 0    | 1   | 0    | 1        | Х | 01  | 0000   | 0xFFFF_FFFF | Cluster guard rule. Set mask, no hash operation since hash bit is 0.                                                                                                                                                   |
| 2     | 0   | 1    | 0   | 0    | 0        | Х | 00  | 1101   | 0x0A0A_0A0A | Compare SIA to 10.10.10.10. If match add SIA to accumulated hash.                                                                                                                                                      |
| 3     | 0   | 0    | 0   | 0    | 1        | X | 00  | 1011   | 0x0000_0011 | Enter AND chain. Match if I4 protocol is UDP, does not get hashed no matter if it matches since hash bit is 0; hash value gets reset to hash value before and chain which is hash value after guard rule if not match. |
| 4     | 0   | 1    | 0   | 0    | 1        | Х | 00  | 1001   | 0x0000_0007 | Compare PRI with 7. If match add PRI to accumulated hash else reset to hash value before and chain which is hash value after guard rule.                                                                               |
| 5     | 0   | 1    | 0   | 0    | 0        | X | 00  | 1110   | 0x0000_0A0A | Exit AND chain. Compare DPT with 0xA0A0. Hash DPT if it matches else reset to hash value before and chain which is hash value after guard rule.                                                                        |
| 6     | 0   | 0    | 1   | 0    | 0        | Х | 00  | 1111   | 0x0000_0505 | Cluster exit. Compare SPT with 0x0505. Hash SPT if matches else reset to hash seed.                                                                                                                                    |

### 15.9.5.2.17 Filer example-interrupt from deep sleep

The example in the table below shows how the filer can facilitate exit from deep sleep if any of the following packets arrive:

- ARP packet with Target IP address matching either of two IP addresses (either static or link local address)
- IPv4/UDP multicast DNS query
- IPv4/UDP SNMP broadcast query

These packets are also be stored in memory. All other packets are dropped.

Table 15-1100. Filer example-interrupt from deep sleep

| Table |     |      |     | RQC | TRL fie | lds     |     |      | RQPROP      | Comment                                                                                                                                                                                                                 |
|-------|-----|------|-----|-----|---------|---------|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| entry | GPI | Hash | CLE | REJ | AND     | Q       | СМР | PID  |             |                                                                                                                                                                                                                         |
| 0     | 0   | 0    | 0   | 0   | 0       | 000_000 | 11  | 0000 | 0x0001_0000 | Check for ARP request; set mask register to mask off everything but the ARP request flag.                                                                                                                               |
| 1     | 0   | 0    | 1   | 0   | 1       | 000_000 | 00  | 0001 | 0x0001_0000 | Check to see if ARP request flag is set<br>by doing a =1 comparison. Enter the<br>"ARP Request Cluster" if true.                                                                                                        |
| 2     | 0   | 0    | 0   | 0   | 0       | 000_000 | 11  | 0000 | 0xFFFF_FFFF | ARP Cluster: Set Mask to unmask everything (Reset mask to all F's)                                                                                                                                                      |
| 3     | 1   | 0    | 0   | 0   | 0       | 000_001 | 00  | 1100 | 0xXXXX_XXXX | Compare the ARP Target IP address against "MY_IP_1", which is indicated by the user-defined value of 0xXXXX_XXXX; if they match, accept the frame and generate an interrupt.                                            |
| 4     | 1   | 0    | 0   | 0   | 0       | 000_001 | 00  | 1100 | 0xYYYY_YYYY | Compare the ARP Target IP address against "MY_IP_2", which is indicated by the user-defined value of 0xYYYY_YYYY; if they match, accept the frame.                                                                      |
| 5     | 0   | 0    | 1   | 1   | 0       | 000_000 | 01  | 0000 | All zeros   | Default rule that will always discard the packet; inserted here because an ARP request was received, but the Target IP address did not match either local IP addresses; therefore drop the packet and exit the cluster. |
| 6     | 0   | 0    | 0   | 0   | 0       | 000_000 | 11  | 0000 | 0x0000_02D0 | Set Mask for IP4 Packet (2D0), with IPv4 checksum checked and verified, and UDP header located.                                                                                                                         |
| 7     | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0001 | 0x0000_02D0 | Check to see if IP4 Packet, with IPv4 checksum checked and verified, and UDP header.                                                                                                                                    |
| 8     | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0000 | 0xFFFF_FFFF | Set Mask to unmask everything (Reset mask to all F's).                                                                                                                                                                  |
| 9     | 0   | 0    | 1   | 0   | 1       | 000_000 | 00  | 1011 | 0x0000_0011 | Check against UDP protocol; if this passes, enter the cluster - all packets in the cluster are IPv4 packets with UDP protocol identified as the L4 protocol type.                                                       |
| 10    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0011 | 0x00XX_XXXX | Compare upper L2 DA bits to XX_XXXX (for multicast DNS query)                                                                                                                                                           |
| 11    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0100 | 0x00YY_YYYY | Compare lower L2 DA bits to YY_YYYY                                                                                                                                                                                     |
| 12    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 1100 | 0xZZZZ_ZZZZ | Compare L3 Destination IP address to ZZZZ_ZZZZ                                                                                                                                                                          |
| 13    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 1110 | 0x0000_XXXX | Compare L4 destination port to XXXX                                                                                                                                                                                     |
| 14    | 1   | 0    | 0   | 0   | 0       | 000_001 | 00  | 1111 | 0x0000_YYYY | If all of the previously consecutive ANDed conditions pass, multicast DNS Query has matched.                                                                                                                            |

Table 15-1100. Filer example-interrupt from deep sleep (continued)

| Table |     |      |     | RQC | TRL fie | elds    |     |      | RQPROP      | Comment                                                                                                                                                                                                                                                          |
|-------|-----|------|-----|-----|---------|---------|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| entry | GPI | Hash | CLE | REJ | AND     | Q       | СМР | PID  |             |                                                                                                                                                                                                                                                                  |
| 15    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0011 | 0x00XX_XXXX | Compare upper L2 DA bits to XX_XXXX (for SNMP broadcast query).                                                                                                                                                                                                  |
| 16    | 0   | 0    | 0   | 0   | 1       | 000_000 | 00  | 0100 | 0x00YY_YYYY | Compare lower L2 DA bits to YY_YYYY.                                                                                                                                                                                                                             |
| 17    | 1   | 0    | 0   | 0   | 0       | 000_001 | 00  | 1110 | 0x0000_ZZZZ | If all of the previously consecutive ANDed conditions pass, SNMP broadcast Query has matched.                                                                                                                                                                    |
| 18    | 0   | 0    | 1   | 1   | 0       | 000_000 | 01  | 0000 | All zeros   | Cluster End: IPv4, UDP Comparison Default rule that will always discard the packet; inserted here because an IPv4 packet with L4=UDP request was received, but the profiles didn't match anything "interesting"; therefore drop the packet and exit the cluster. |
| 19    | 0   | 0    | 0   | 1   | 0       | 000_000 | 01  | 0000 | All zeros   | Default rule that will always discard the packet; inserted here no matches for any "interesting" packets were received that are used to wake up the CPU. All packets that reach this rule are discarded.                                                         |

# 15.9.5.3 Transmission scheduling

Each eTSEC can maintain multiple TxBD rings (or transmission queues) to satisfy QoS requirements.

The ability to choose from a number of transmission streams dynamically is especially important during periods of network congestion. Certain application such as voice and video streaming are delay sensitive, but loss insensitive. For instance, VoIP applications require little bandwidth, but are highly sensitive to latency. Conversely, FTP or SMTP protocols are delay insensitive, but loss sensitive.

eTSEC has a transmission scheduler that implements a programmable QoS regime. The scheduler is responsible for choosing which of the prefetched TxBDs shall be processed next and accordingly issuing DMA requests to service the data stream described by the chosen BD(s). The scheduler cycle as follows:

- 1. Decide on a TxBD queue
- 2. Transmit exactly one frame from that queue.
- 3. Return to deciding on another queue, in step 1.

If TCTRL[TXSCHED] is set to 00, no transmission scheduling occurs, and only TxBD ring 0 is polled for new data to transmit, with DMACTRL controlling waiting or polling. TCTRL[TXSCHED], if not zero, can be programmed to invoke one of two scheduling algorithms, namely priority-based queuing (PBQ), and modified weighted round-robin queuing (MWRR). In all cases where TCTRL[TXSCHED] is not zero, the scheduler can choose from among 1 to 8 TxBD rings per eTSEC, with individual rings being enabled by the setting of TQUEUE[EN0-EN7] bits. For example, TxBD rings 3, 4, and 7 may be enabled for scheduling by setting EN3, EN4, and EN7, and clearing all other EN bits.

## 15.9.5.3.1 Priority-based queuing (PBQ)

PBQ is the simplest scheduler decision policy.

The enabled TxBD rings are assigned a priority value based on their index. Rings with a lower index have precedence over rings with higher indices. For example, TxBD ring 0 has higher priority than TxBD ring 1, and TxBD ring 1 has higher priority than TxBD ring 2, and so on.

The scheduling decision is then achieved as follows:

In practice a protocol stack or device driver can abuse PBQ by attempting to queue too much traffic onto high priority rings. It is recommended that the highest priority ring should normally not be used at all except for frames requiring the utmost urgent transmission. This allows emergency traffic to overtake backlogged queues out of sequence.

## 15.9.5.3.2 Modified weighted round-robin queuing (MWRR)

eTSEC implements a modified weighted round-robin scheduling algorithm across all enabled TxBD rings when TCTRL[TXSCHED] = 10.

In MWRR, the weights in the TR03WT and TR47WT registers determine the ideal size of each transmit slot, as measured in multiples of 64 bytes. Thus, to set a transmit slot of 512 bytes, a weight of 512/64 or 8 needs to be set for the ring. For single-group mode,

with MWRR arbitration TxBD rings 1-7 are selected in round-robin fashion, whereas TxBD ring 0, if enabled with ready data for transmission, is always selected in between other rings so as to expedite transmission from ring 0. For multiple-group mode, ring 0 is treated like any other queue for MWRR: TxBD rings 0-7 are selected in round-robin fashion. A ring may be slightly penalized if its credit goes negative at the time the ring is detected as being empty. In such cases, its credit would reset to minus one instead of zero.

```
// MWRR MULTI-GROUP MODE
while ((ISRG0!=0) or (ISRG1!=0) or (ISRG2!=0)or (ISRG3!=0)) loop
    for ring = N...7 and enabled(ring) loop
      credit[ring] = weight[ring];
    endloop // for ring = N..7 and enabled(ring)
    while ((a_ring_enabled)) loop
      for ring = N...7 and enabled(ring) loop
            while (GTS) loop
            N=0;
            ring=0;
            endloop // while (GTS)
            if not ring_halted(ring) then
            if credit[ring] <= 0 then
                   credit[ring] = credit[ring] + weight[ring];
             endif
            while ((credit[ring] > 0) and not GTS) loop
                   transmit_frame(ring);
                  credit[ring] = credit[ring] - frame_debit;
             endloop // while ((credit[ring] > 0) and not GTS)
            if ring_empty(ring) and credit[ring] >= 0 then
                   credit[ring] = 0;
            if ring_empty(ring) and credit[ring] < 0 then
                   credit[ring] = -1;
             endif
            if (not ring_halted(ring) and (credit[ring] <= 0) and not GTS) then
                   credit[ring] = credit[ring] + weight[ring];
            endif// if (not ring_halted(ring) and (credit[ring] <= 0) and not GTS)</pre>
            endif // if not ring_halted(ring)
      endloop // for ring = N..7 and enabled(ring)
    endloop // while ((a_ring_enabled))
endloop // MWRR MULTI-GROUP MODE
// NOTE: A ring that is empty will halt once the processing of the last frame in the ring
```

The algorithm checks registers TQUEUE[EN0-EN7] for enabled(), TSTATn[THLT0-THLT7] for ring\_empty(), and TRxWT for weight(). For TxBD ring k, having a weight WTk, the long term average throughput for that ring is:

Single-group mode:

```
rate of queue[k] = (available bandwidth) * WTk/(sum(WTi) + 6WT0)
rate of queue(0) = (available bandwidth) * 7 * WT0/(sum(WTi) + 6WT0)
where i = 0 to 7, and k = 1 to 7
```

```
Multiple-group mode:

rate of queue[k] = (available bandwidth) * WTk/(sum(WTi))
```

#### 15.9.6 Lossless flow control

where i = 0 to 7, and k = 0 to 7

The eTSEC DMA subsystem is designed to be able to support simultaneous receive and transmit traffic at gigabit line rates.

If the host memory has sufficient bandwidth to support such line rates, then the principle cause of overflow on receive traffic is due to a lack of Rx BDs. Thus, the long term receive throughput is determined by the rate at which software can process receive traffic. If a user desires to prevent dropped packets, they can inform the far-end link to stop transmission while the software processing catches up with the backlog.

To avoid overflow in the latter case, back pressure must be applied to the far-end transmitter before the Rx descriptor controller encounters a non-empty BD and halts with a BSY error. As there is lag between application of back-pressure and response of the far-end, the pause request must be issued while there are still BDs free in the ring. In the traditional eTSEC descriptor ring programming model, there is no way for hardware to know how many free BDs are available, so software must initiate any pause requests required during operation. If software is backlogged, the request may be not be issued in time to prevent BSY errors. To allow the eTSEC to generate the pause request automatically, additional information (a pointer the last free BD and ring length) is required.

## 15.9.6.1 Back pressure determination through free buffers

Ultimately, the rate of data reception is determined by how quickly software can release buffers back into the receive ring(s).

Each time a buffer is freed, the associated BD has its empty bit set and hardware is free to consume both. Thus the number of free BDs in a given Rx ring indicates how close hardware is to the end of that ring. To prevent data loss, back pressure should be applied when the number of free BDs drops below some critical level. The number of BDs that can be consumed by an incoming packet stream while back-pressure takes effect is determined by several factors, such as: receive traffic profile, transmit traffic profile, Rx buffer size, physical transmission time between eTSEC and far-end device and intradevice latency. Theoretically, the worst case is as follows:

$$FreeBDsRequired = \frac{MaxFrameSize}{MinFrameSize + IFG} + \frac{MaxFrameSize}{RxBufferSize} + LinkDelay$$

This case comes about when one of the following occurs:

- The eTSEC has just started transmitting a large frame and thus cannot send out a pause frame.
- Upon reception of the pause request the far-end has just started transmission of a large frame.
- The eTSEC receives a burst of short frames with minimum inter-frame-gap (96bit times for Ethernet).

Once the user has determined the worst case scenario for their application, they program the required free BD threshold into the eTSEC (through RQPRM[PBTHR]). Since different BD rings may have different sizes and expected packet arrival rates, a separate threshold is provided for each active ring. It is recommended that a threshold of at least four BDs is the practical minimum for gigabit ethernet links.

For the Rx descriptor controller to determine the number of free BDs remaining in the ring, it needs to know the following:

- The location of the current BD being used by hardware.
- The location of the last BD that was released (freed) by software.
- The length of the Rx BD ring.

For each active ring, the current BD pointer (RBPTR*n*) is maintained by the eTSEC. Software knows both the size of the Rx ring and the location of the last freed BD. By providing the eTSEC with those values (through RQPRM[LEN] and RFBPTR respectively) the eTSEC always know how many receive buffers are available to be consumed by incoming data.

The number of guaranteed free BDs in the ring is then determined by:

When RFBPTRn < RBPTRn

$$FreeBDs = RQPRMn[LEN] - RBPTRn + RFBPTRn$$

When RFBPTRn > RBPTRn

$$FreeBDs = RFBPTRn - RBPTRn$$

When RBPTRn = RFBPTRn the number of free BDs in the ring is either one (since RFBPTRn points to a free BD) or equal to the ring length. Since the BD pointed to by RBPTRn may be either in use or about to be used, it is not considered in the free BD count. To resolve the case where the two pointers collide, the following logic applies:

- If RBASE*n* was updated and thus initializes both RBPTR*n* and RFBPTR*n*, the ring is deemed empty.
- If RFBPTR*n* is updated by a software write and matches RBPTR*n*, the ring is deemed empty.
- If hardware updates RBPTR*n* and the result matches RFBPTR*n*, the ring is deemed to have one BD remaining. Upon writing this BD back to memory (indicating the buffer is occupied) the ring is deemed to be full.

#### NOTE

There is a possibility that if software is severely backlogged in updating RFBPTRn, the hardware can wrap around the ring entirely, consume exactly the remaining number of BDs, and not halt with a BSY error. If software then increments RFBPTRn to the next address (thereby equalling RBPTRn), the hardware assumes the ring is now empty (when in fact there is only a single BD freed up). This results in the hardware failing to maintain back pressure on the far end. Upon software incrementing RFBPTRn a subsequent time, the wrap condition is successfully detected and hardware recognizes a nearly full ring (rather than a nearly empty one). Because software can increment RFBPTRn by any amount, it is not possible for hardware to determine in this case whether the user has cleared the entire ring or just one BD. Users can eliminate the possibility of this condition occurring by ensuring that RFBPTRn is incremented by at least two BDs each time (that is, clear at least two buffers whenever the RxBD unload routine is called).

Once the eTSEC determines that this threshold has been reached, back pressure is applied accordingly. The type of back pressure that is applied varies according to the physical interface that is used.

- Half duplex Ethernet: No support in this mode.
- Full duplex Ethernet: An IEEE 802.3 PAUSE frame (see Flow control) is issued as if the TCTRL[TFC\_PAUSE] bit was set. An internal counter tracks the time the far end controller is expected to remain in pause (based on the setting of PTV[PT]). When that counter reaches half the value of PTV[PT], the eTSEC reissues a pause frame if the free BD calculation for any ring is below the threshold for that ring. For

- example, if PTV[PT] is set to 10 quanta, a pause frame is re-issued when five quanta have elapsed if the free BD threshold is still not met. A practical minimum for PTV[PT] of 4 quanta is recommended.
- **FIFO packet interface:** Link layer flow control is asserted through use of the RFC signal (CRS pin). Flow control is asserted for the entire time that free BD threshold is not met. The same mechanism is used for both GMII-style and encoded packet modes.

## 15.9.6.2 Software use of hardware-initiated back pressure

The following subsections discuss initialization and operation.

#### 15.9.6.2.1 Initialization

Software configures RBASEn and RQPRMn[LEN] according to the parameters for that ring.

Then the number of free BDs that are required to prevent the eTSEC from automatically asserting flow control are programmed in RQPRM[FBTHR]. The receiver is then enabled.

Note that the act of programming RBASE*n* initializes RFBPTR*n* to the start of the ring. When the ring is in this initial empty state, there is no concept of a last freed BD. In this case, the calculated number of free BDs is the size of the ring. Because the BD that the hardware is currently pointing to is to be considered in-use, the free BD count is actually one higher than the total available. As soon as the hardware consumes a BD (by writing it back to memory), RBPTR*n* advances and the free BD count reflects the correct number of available free BDs.

## 15.9.6.2.2 Operation

As software frees BDs from the ring, it writes the physical address of the BD just freed to RFBPTR*n*.

The eTSEC asserts flow control if the distance (using modulo arithmetic) between RBPTRn and RFBPTRn is < RQPRMn[FBTHR]. In multi-ring operation, if the free BD count of **any** active ring drops below the threshold for that ring, flow control is asserted. Once enough BDs are freed for **all** active rings to meet their respective free BD thresholds, application of back pressure cases.

#### **Functional description**

Note that the eTSEC does not issue an exit pause frame (that is, pause frame with PTV of 0x0000) once all active rings have sufficient BDs. Instead, it waits for the far-end pause timer to expire and start re-transmission.

# 15.9.7 Hardware assist for IEEE Std. 1588 compliant timestamping

There is a push in industrial control applications to use Ethernet as the principal link layer for communications. This requires Ethernet to be used for both data transfer and real-time control. For real-time systems, each node is required to be synchronized to a master clock. The precision of this clock is dictated by the application, but generally needs to be of the order of < 1µs for high-speed machinery such as printing presses.

IEEE 1588 [1588] specifies a mechanism for synchronizing multiple nodes to a master clock. Support for 1588 can be done entirely in software running on a host CPU, but applications that require sub 10 µs accuracy need hardware support for accurate time stamping of incoming packets.

The eTSEC includes a new timer clock module to support the IEEE Std. 1588 timer standard. The following sections describe the features, programming model, and implementation information.

## 15.9.7.1 Features

The main features are as follows:

- 64-bit free running timer running from an external oscillator or internal clock
- Programmable timer oscillator clock selection
- Self-correcting precision timer with nanosecond resolution
- Time stamp all incoming packets inline
  - Maskable interrupts on received PTP packet's filer rule match
- Time stamp transmit packets when instructed in the TxFCB
  - Maskable interrupts on transmit time stamp capture
- Two Tx time stamp registers per eTSEC with 16-bit tag for each of them to support burst mode.
- Time stamp capture on two general-purpose external triggers
  - Maskable interrupts on GPIO time stamp trigger
  - Programmable polarity of external trigger (GPIO) edge
- Two 64-bit alarm (future time) registers for future time comparison
  - Maskable interrupts on alarm

- Three programmable timer output pulse period phase aligned with 1588 timer clock
  - Maskable interrupts associated with each pulse
- Separate maskable timer interrupt event register
- Recognition of incoming PTP packet through filer rule match
- Phase aligned adjustable (divide by N) clock output
- Supports all Ethernet modes supported by the eTSEC, including full- and half-duplex modes
- Supports both master and slave modes
- Supports time stamp of nanosecond resolution

## 15.9.7.2 Timer logic overview



Figure 15-1067. 1588 Timer design partition



Figure 15-1068. 1588 Current time control

The 64-bit current time is controlled by timer enable, TMR\_CTRL[TE], selected clock, TMR\_CTRL[CKSEL], bypass mode, TMR\_CTRL[BYP], the timer clock period, TMR\_CTRL[TCLK\_PERIOD], and the ADDEND value, TMR\_ADD registers, as shown in Figure 15-1068.

## 15.9.7.3 Time stamp insertion on the received packets

Every incoming packet's 8-byte time stamp is inserted into the packet data buffer as padding alignment bytes.

Time stamp insertion into the data buffer requires RCTRL[PAL] to be set to a value greater than or equal to 8 and the control bit RCTRL[TS] bit to be set.

## **15.9.7.3.1** Time stamp point

The required time stamp point, as specified in the IEEE 1588 Specification Sep-2004 (IEC 61588 First Edition), is shown in the figure below.

From this, it is clear that the end of the SFD is the critical point in the MII data stream.



Figure 15-1069. Ethernet sampling points for 1588

The sample point coincides with the cycle after the SFD (Start of Frame Delimiter) detection by the MAC. For received frames, this will be at least 4 bit times (MII) or 8 bit times (GMII) after the message time stamp point specified in [1588]. For transmission, the eTSEC sample point precedes the sample point specified in [1588] by at least 4-bit times (MII) or 8-bit times (GMII). For a particular mode, the eTSEC sample point is a consistent number of bit times relative to the SFD detection. Thus, the offset from the [1588] specified sample point can be accounted for in the PTP software implementation.

# 15.9.7.4 PTP packet parsing

PTP packets are typically embedded within a UDP payload with special IP source and destination address and special source and destination ports numbers.

Special fields of interest of a PTP packet are listed in the table below.

| Field          |     | Value       | oTSEC filor |
|----------------|-----|-------------|-------------|
| Table 15-1101. | FIF | payioau spe | eciai neius |

| Layer      | Octet (offset from the SFD) | Field                                                                      | Value                                                    | eTSEC filer PID                            | Comments                                                                     |
|------------|-----------------------------|----------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------|------------------------------------------------------------------------------|
| Ethernet   | 12-13                       | Length/Packet                                                              | 0x0800                                                   | ETY-<br>RQPFR[PID=0111]                    | IPv4                                                                         |
| IP header  | 22                          | Time to live                                                               | 0x00                                                     | RBIFX- choose an arbitrary extraction byte | Must be 0                                                                    |
| IP header  | 23                          | IP Protocol                                                                | 0x11                                                     | L4P-<br>RQPFR[PID=1011]                    | UDP                                                                          |
| IP header  | 26-29                       | Source IP Address IANA defines 4 multicast address for the PTP packet      | -                                                        | SIA-<br>RQPFR[PID=1101]                    | -                                                                            |
| IP header  | 30-33                       | Destination IP Address IANA defines 4 multicast address for the PTP packet | 224.0.1.129<br>224.0.1.130<br>224.0.1.131<br>224.0.1.132 | DIA-<br>RQPFR[PID=1100]                    | DefaultPTPdomain AlternatePTPdomain1 AlternatePTPdomain2 AlternatePTPdomain3 |
| UDP header | 34-35                       | Source port number                                                         | -                                                        | SPT-<br>RQPFR[PID=1011]                    | -                                                                            |
| UDP header | 36-37                       | Destination port number                                                    | 319<br>320                                               | DPT-<br>RQPFR[PID=1011]                    | EventPort<br>GeneralPort                                                     |
| UDP data   | 74                          | Control                                                                    | 0x0                                                      | RBIFX- choose an                           | Sync                                                                         |
|            |                             |                                                                            | 0x1                                                      | arbitrary extraction byte                  | Delay_req                                                                    |
|            |                             |                                                                            | 0x2                                                      |                                            | Follow_up                                                                    |
|            |                             |                                                                            | 0x3                                                      |                                            | Delay_resp                                                                   |
|            |                             |                                                                            | 0x4                                                      |                                            | Management                                                                   |



Figure 15-1070. PTP packet format

## 15.9.7.4.1 General purpose filer rule

The eTSEC receive filer has been enhanced with the addition of a general-purpose event bit. This event bit can be used in conjunction with filing table rules to identify 1588 packets and indicate these packets by setting special timer status register bits (TMR\_STAT). Additionally, 1588 packets can be easily identified by upper-layer software by using the filer to queue all PTP packets to one or more predefined virtual queues. See Filing rules, for further information.

## 15.9.7.5 Time stamp insertion on transmit packets

Software has the option to write the time stamp of the transmitted frame to memory in the padding alignment bytes (PAL) located between the TxFCB and the frame data.

It is required that a minimum of two TxBDs are used. The first points to the start of the 8 byte TxFCB. The second points to the start of frame data. In memory, the TxFCB, and at least the first 16 bytes of the TxPAL must be adjacent, i.e., located in continguous memory locations, as depicted in Figure 15-1071.

The first TxBD[TOE] bit is set. When the TMR\_CTRL[Record Time-stamp In PAL Enable] and TxFCB[PTP] bits are set, the time stamp is written to memory location TxBD[Data Buffer Pointer]+16.

The second TxBD's Data Length must either contain the full frame length, or a value greater than the TxThreshold setting. Refer to Table 15-1102. When time stamps are inserted into the TxPAL, the TMR\_TXTSn\_H/L and TMR\_TXTSn\_ID registers still function normally.

## 15.9.7.5.1 Interrupts

The TxPAL is updated with a time stamp before closing the second TxBD.

The TxBD[I] bit can be set for the second TxBD frame to cause an interrupt (via IEVENTGg[TXF]) after the time-stamp has been written to the TxPAL.

When time stamps are inserted into the TxPAL, the TMR\_TXTS*n*\_H/L and TMR\_TXTS*n*\_ID registers still function normally. Therefore, the 1588 interrupt can be triggered by using the TMR\_PEVENT register bits TXP1, and TXP2.

Table 15-1102. Time stamp insertion programming requirements

| Requirement        | Behavior if requirement is not met                          |
|--------------------|-------------------------------------------------------------|
| TMR_CTRL[RTPE] = 1 | If TMR_CTRL[RTPE] = 0, no time stamp is written to a TxPAL. |

Table 15-1102. Time stamp insertion programming requirements (continued)

| Requirement                                                              | Behavior if requirement is not met                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxBD[TOE] = 1                                                            | If TxBD[TOE] = 0, no time stamp is written to a TxPAL.                                                                                                                                                                                                   |
| First TxBD[data buffer pointer] is 8-byte aligned                        | The time stamp is written to address First TxBD[Data Buffer Pointer] + 0x10 rounded down to the nearest 8-byte aligned address, except at 4K page boundaries, in which case the time stamp may be invalid and the second TxBD close status will be lost. |
| First TxBD[data length] = 8, 8 bytes for TxFCB                           | If L2 or frame data is included in the Length, the buffer immediately following the FCB is transmitted on the line and the frame data stored in memory will be overwritten with a time-stamp value after the frame is transmitted.                       |
| TxFCB[PTP] = 1                                                           | If TxBD[PTP] = 0, no time stamp is written to a TxPAL.                                                                                                                                                                                                   |
| The TxFCB is followed immediately by a minimum of 16 bytes for the TxPAL | The time stamp is written to address First TxBD[Data Buffer Pointer] + 0x10.                                                                                                                                                                             |
| Second TxBD[data buffer pointers] points to start of L2 or frame data    | If there is only one TxBD used to transfer a PTP frame, no time stamp is written to a TxPAL.                                                                                                                                                             |
| Second TxBD[data length] ≥ FIFO_TX_THR or includes the entire frame      | If this condition is not true, the time-stamp in TxPAL is invalid.                                                                                                                                                                                       |



Figure 15-1071. Buffer format for transmit time-stamp insertion

## 15.9.7.5.2 **Error condition**

When an error is encountered after a PTP packet has begun to be processed, the time stamp written to the TxPAL is zero.

Subsequent frames may be flushed by eTSEC. There will be no time-stamp update to TxPAL for the subsequent flushed frames.

## 15.9.7.6 Tx PTP packet parsing

Software instructs the Tx packet to be time stamped by setting bit 15 in the TxFCB to mark a PTP packet. TxFCB[VLCTL] can be translated as the Tx PTP packet identification number. BD[TOE] must be set to enable transmit PTP packet time stamping. TxFCB[PTP] bit takes precedence over TxFCB[VLN] bit. It disables per packet VLAN tag insertion. On a PTP packet, a VLAN tag can be inserted from the DFVLAN register.

3 4 6 8 9 10 | 11 | 12 | 13 | 14 Offset + 0 ٧L ΙP IP TU PΤ **UDP** CI CT Ν Р 6 Н Offset + 2 L4OS L3OS Offset + 4 **PHCS** VLCTL/PTP\_ID Offset + 6

Table 15-1103. Transmit frame control block

#### **Functional description**

# Table 15-1104. Tx frame control block description

| Bytes | Bits | Name | Description                                                                                                                                                                                                                                          |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1   | 0    | VLN  | VLAN control word valid. This bit is ignored when the PTP bit is set. VLAN tag is read from the DFVLAN register if PTP = 1.                                                                                                                          |
|       |      |      | 0 Ignore VLCTL field.                                                                                                                                                                                                                                |
|       |      |      | 1 If VLAN tag insertion is enabled for eTSEC, use the VLCTL field as the VLAN control word.                                                                                                                                                          |
|       | 1    | IP   | Layer 3 header is an IP header.                                                                                                                                                                                                                      |
|       |      |      | 0 Ignore layer 3 and higher headers.                                                                                                                                                                                                                 |
|       |      |      | 1 Assume that the layer 3 header is an IPv4 or IPv6 header, and take L3OS field as valid.                                                                                                                                                            |
|       | 2    | IP6  | IP header is IP version 6. Valid only if IP = 1.                                                                                                                                                                                                     |
|       |      |      | 0 IP header version is 4.                                                                                                                                                                                                                            |
|       |      |      | 1 IP header version is 6.                                                                                                                                                                                                                            |
|       | 3    | TUP  | Layer 4 header is a TCP or UDP header.                                                                                                                                                                                                               |
|       |      |      | 0 Do not process any layer 4 header.                                                                                                                                                                                                                 |
|       |      |      | 1 Assume that the layer 4 header is either TCP or UDP (see UDP bit), and offload checksumming on the basis that the IP header has no extension headers.                                                                                              |
|       | 4    | UDP  | UDP protocol at layer 4.                                                                                                                                                                                                                             |
|       |      |      | 0 Layer 4 protocol is either TCP (if TUP = 1) or undefined.                                                                                                                                                                                          |
|       |      |      | 1 Layer 4 protocol is UDP if TUP = 1.                                                                                                                                                                                                                |
| 0-1   | 5    | CIP  | Checksum IP header enable.                                                                                                                                                                                                                           |
|       |      |      | 0 Do not generate an IP header checksum.                                                                                                                                                                                                             |
|       |      |      | 1 Generate an IPv4 header checksum.                                                                                                                                                                                                                  |
|       | 6    | CTU  | Checksum TCP or UDP header enable.                                                                                                                                                                                                                   |
|       |      |      | 0 Do not generate a TCP or UDP header checksum. RFC 768 advises that UDP packets not requiring checksum validation should have their checksum field set to zero.                                                                                     |
|       |      |      | 1 Generate a TCP header checksum if IP = 1 and TUP = 1 and UDP = 0.                                                                                                                                                                                  |
|       | 7    | NPH  | Disable calculation of TCP or UDP pseudo-header checksum. This bit should be set if IP options need to be consulted in forming the pseudo-header checksum, as eTSEC does not examine IP options or extension headers for TCP/IP offload on transmit. |
|       |      |      | 0 Calculate TCP or UDP pseudo-header checksum as normal, assuming that the IP header has no options.                                                                                                                                                 |
|       |      |      | 1 Do not calculate a TCP or UDP pseudo-header checksum, but instead use the value in field PHCS when determining the overall TCP or UDP checksum.                                                                                                    |
|       | 8-14 | -    | Reserved                                                                                                                                                                                                                                             |
|       | 15   | PTP  | Indication to the transmitter that this is a PTP packet. Enabling PTP disables per packet VLAN tag insertion. Instead, VLAN tag will be read from the DFVLAN when the PTP field is true.                                                             |
|       |      |      | 0 Do not attempt to capture transmission event time                                                                                                                                                                                                  |
|       |      |      | 1 Valid PTP_ID field. When this packet is transmitted, capture the time of transmission.                                                                                                                                                             |
|       |      |      | Must be clear if TMR_CTRL[TE] is clear.                                                                                                                                                                                                              |

Table 15-1104. Tx frame control block description (continued)

| Bytes | Bits | Name        | Description                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2-3   | 0-7  | L4OS        | Layer 4 header offset from start of layer 3 header. The layer 4 header starts L4OS octets after the layer 3 header if it is present. The maximum layer 3 header length supported is thus 255 bytes, which may prevent TCP/IP offload on particularly large IPv6 headers.     |
|       | 8-15 | L3OS        | Layer 3 header offset from start of frame not including the 8 bytes for this FCB. The layer 3 header starts L3OS octets from the start of the frame including any custom preamble header that may be present. The maximum layer 2 header length supported is thus 255 bytes. |
| 4-5   | 0-15 | PHCS        | Pseudo-header checksum (16-bit one's complement sum with carry wraparound, but without result inversion) for TCP or UDP packets, calculated by software. Valid only if NPH = 1.                                                                                              |
| 6-7   | 0-15 | VLCTL       | VLAN control word for insertion in the transmitted VLAN tag. Valid only if VLN = 1.                                                                                                                                                                                          |
|       |      | /<br>PTP_ID | Tx PTP packet identification number. This number will be copied into the Tx PTP packet time stamp identification field. PTP field takes precedence over VLN field.                                                                                                           |

# 15.9.8 Buffer descriptors

The eTSEC buffer descriptor (BD) is modeled after the MPC8260 Fast Ethernet controller BD for ease of reuse across the PowerQUICC network processor family.

Drawing from the MPC8260 FEC BD programming model, the eTSEC descriptor base registers point to the beginning of BD rings. The eTSEC BD also expands upon the MPC8260 BD model to accommodate the eTSEC's unique features. However, the 8-byte data BD format is designed to be compatible with the existing MPC8260 BD model.

The eTSEC is capable of duplicating-or extracting-data directly into the L2 cache memory. This allows the processor to quickly access critical frame information as soon as the processor is ready without having to first fetch the data from main memory, which holds the master copy. This results in substantial improvement in throughput and hence reduction in latency.

## 15.9.8.1 Data buffer descriptors

Data buffers are used in the transmission and reception of Ethernet frames (see Figure 15-1072).

Data BDs encapsulate all information necessary for the eTSEC to transmit or receive an Ethernet frame.

Within each data BD there is a status field, a data length field, and a data pointer. The BD completely describes an Ethernet packet by centralizing status information for the data packet in the status field of the BD and by containing a data BD pointer to the location of the data buffer. Software is responsible for setting up the BDs in memory. A minimum of

#### **Functional description**

nine buffer descriptors must be used when wrapping back to the top BD of the ring. This applies to both the transmit and the receive descriptor rings. Transmit rings are limited to a maximum size of 65536 BDs due to BD and frame data prefetching. Software also must have the data pointer pointing to a legal memory location. Within the status field, there exists an ownership bit which defines the current state of the buffer (pointed to by the data pointer). Other bits in the status field of the buffer descriptor are used to communicate status/control information between the eTSEC and the software driver.

Because there is no next BD pointer in the transmit/receive BD (see Figure 15-1073), all BDs must reside sequentially in memory. The eTSEC increments the current BD location appropriately to the next BD location to be processed. There is a wrap bit in the last BD that informs the eTSEC to loop back to the beginning of the BD chain. Software must initialize the TBASE and RBASE registers that point to the beginning transmit and receive BDs for eTSEC.



Figure 15-1072. Example of eTSEC Memory Structure for BDs



Figure 15-1073. Buffer descriptor ring

## 15.9.8.2 Transmit data buffer descriptors (TxBD)

Data is presented to the eTSEC for transmission by arranging it in memory buffers referenced by the TxBDs.

In the TxBD the user initializes the R, PAD, W, I, L, TC, PRE, HFE, CF, and TOE bits and the length (in bytes) in the first word, and the buffer pointer in the second word. Unused fields or fields written by the eTSEC must be initialized to zero.

The eTSEC clears the R bit in the first word of the BD after it finishes using the data buffer. The transfer status bits are then updated. Additional transmit frame status can be found in statistic counters in the MIB block.

Software must expect eTSEC to prefetch multiple TxBDs, and for TCP/IP checksumming an entire frame must be read from memory before a checksum can be computed. Accordingly, the R bit of the first TxBD in a frame must not be set until at least one entire frame can be fetched from this TxBD onwards. If eTSEC prefetches TxBDs and fails to reach a last TxBD (with bit L set), it halts further transmission from the current TxBD ring and report an underrun error as IEVENTGg[XFUN]; this indicates that an incomplete frame was fetched, but remained unprocessed. The relevant TBPTR register points to the next unread TxBD following the error.

Table 15-1105. Transmit buffer descriptor



## Table 15-1105. Transmit buffer descriptor (continued)

| Offset + 0 | R | PAD/CRC                | W | I | L | TC | PRE/DEF | - | HFE/LC | CF/RL/<br>EX | RC | TOE/UN | TR |
|------------|---|------------------------|---|---|---|----|---------|---|--------|--------------|----|--------|----|
| Offset + 2 |   | DATA LENGTH            |   |   |   |    |         |   |        |              |    |        |    |
| Offset + 4 |   | TX DATA BUFFER POINTER |   |   |   |    |         |   |        |              |    |        |    |
| Offset + 6 |   |                        |   |   |   |    |         |   |        |              |    |        |    |

The TxBD definition is interpreted by eTSEC hardware as if TxBDs mapped to C data structures in the manner illustrated by the following code.

```
typedef unsigned short uint_16; /* choose 16-bit native type */
typedef unsigned int uint_32; /* choose 32-bit native type */
typedef struct txbd_struct {
    uint_16 flags;
    uint_16 length;
    uint_32 bufptr;
} txbd;
```

#### Table 15-1106. Transmit data buffer descriptor (TxBD) field descriptions

| Offset | Bits | Name    | Description                                                                                                                                                                                                                                                       |
|--------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1    | 0    | R       | Ready, written by eTSEC and user.                                                                                                                                                                                                                                 |
|        |      |         | 0 The data buffer associated with this BD is not ready for transmission. The user is free to manipulate this BD or its associated data buffer. The eTSEC clears this bit after the buffer is transmitted or after an error condition is encountered.              |
|        |      |         | 1 The data buffer, which is prepared for transmission by the user, was not transmitted or is currently being transmitted. No fields of this BD may be written by the user once this bit is set.                                                                   |
|        | 1    | PAD/CRC | Padding for frames. (Valid only while it is set in the first BD and MACCFG2[PAD enable] is cleared). If MACCFG2[PAD enable] is set, this bit is ignored.                                                                                                          |
|        |      |         | 0 Do not add padding to short frames.                                                                                                                                                                                                                             |
|        |      |         | 1 Add PAD to frames. PAD bytes are inserted until the length of the transmitted frame equals 64 bytes. Unlike the MPC8260 which PADs up to MINFLR value, the eTSEC PADs always up to the IEEE minimum frame length of 64 bytes. CRC is always appended to frames. |
|        | 2    | W       | Wrap. Written by user. The earliest this bit can be set, is on the ninth BD of a ring.                                                                                                                                                                            |
|        |      |         | 0 The next buffer descriptor is found in the consecutive location.                                                                                                                                                                                                |
|        |      |         | 1 The next buffer descriptor is found at the location defined in TBASE.                                                                                                                                                                                           |
|        | 3    | I       | Interrupt. Written by user.                                                                                                                                                                                                                                       |
|        |      |         | 0 No interrupt is generated after this buffer is serviced.                                                                                                                                                                                                        |
|        |      |         | IEVENTGg[TXB] or IEVENTGg[TXF] are set after this buffer is serviced. These bits can cause an interrupt if they are enabled (That is, IEVENTGg[TXBEN] or IEVENTGg[TXFEN] are set).                                                                                |
|        | 4    | L       | Last in frame. Written by user.                                                                                                                                                                                                                                   |
|        |      |         | 0 The buffer is not the last in the transmit frame.                                                                                                                                                                                                               |
|        |      |         | 1 The buffer is the last in the transmit frame.                                                                                                                                                                                                                   |

Table 15-1106. Transmit data buffer descriptor (TxBD) field descriptions (continued)

| Offset | Bits  | Name | Description                                                                                                                                                                                                                                                                       |
|--------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | 5     | TC   | Tx CRC. Written by user. (Valid only while it is set in first BD and TxBD[PAD/CRC] is cleared and MACCFG2[PAD/CRC enable] is cleared and MACCFG2[CRC enable] is cleared.) If MACCFG2[PAD/CRC enable] is set or MACCFG2[CRC enable] is set, this bit is ignored in ethernet modes. |
|        |       |      | 0 End transmission immediately after the last data byte with no hardware generated CRC appended, unless TxBD[PAD/CRC] is set.                                                                                                                                                     |
|        |       |      | 1 Transmit the CRC sequence after the last data byte.                                                                                                                                                                                                                             |
|        | 6     | PRE  | Transmit user-defined Ethernet preamble. Written by user. Valid only if set in the first BD of a frame, and MACCFG2[PreAm TxEN] is set.                                                                                                                                           |
|        |       |      | 0 This frame does not contain Ethernet preamble bytes for transmission.                                                                                                                                                                                                           |
|        |       |      | 1 This frame includes a user-defined Ethernet preamble sequence prior to the destination address in the data buffer.                                                                                                                                                              |
|        |       | DEF  | Defer indication. The eTSEC updates this bit after transmitting a frame (TxBD[L] is set)                                                                                                                                                                                          |
|        |       |      | 0 This frame was not deferred.                                                                                                                                                                                                                                                    |
|        |       |      | This frame did not have a collision before it was sent but it was sent late because of deferring                                                                                                                                                                                  |
|        | 7     | -    | Reserved                                                                                                                                                                                                                                                                          |
| 0-1    | 8     | HFE  | Huge frame enable. Written by user. Valid only if set in the first BD of a frame and MACCFG2[Huge Frame] is cleared. If MACCFG2[Huge Frame] is set, this bit is ignored.                                                                                                          |
|        |       |      | 0 Truncate transmit frame if its length is greater than the MAC's maximum frame length.                                                                                                                                                                                           |
|        |       |      | 1 Allow large frames to be transmitted without truncation.                                                                                                                                                                                                                        |
|        |       | LC   | Late collision. Written by the eTSEC.                                                                                                                                                                                                                                             |
|        |       |      | 0 No late collision.                                                                                                                                                                                                                                                              |
|        |       |      | 1 A collision occurred after 64 bytes are sent. The eTSEC terminates the transmission and updates LC.                                                                                                                                                                             |
|        | 9     | CF   | Control Frame. Written by user. Valid only if set in the first BD of a frame.                                                                                                                                                                                                     |
|        |       |      | 0 Regular frame; transmission is deferred when eTSEC is in PAUSE.                                                                                                                                                                                                                 |
|        |       |      | 1 Control frame; transmission starts even if eTSEC is in PAUSE.                                                                                                                                                                                                                   |
|        |       | RL   | Retransmission Limit. Written by the eTSEC.                                                                                                                                                                                                                                       |
|        |       |      | 0 Transmission before maximum retry limit is hit.                                                                                                                                                                                                                                 |
|        |       |      | 1 The transmitter failed (max. retry limit + 1) attempts to successfully send a message due to repeated collisions. The eTSEC terminates the transmission and updates RL.                                                                                                         |
|        |       | EX   | Excessive defer. Written by the eTSEC.                                                                                                                                                                                                                                            |
|        |       |      | 0 No excessive defer condition sent.                                                                                                                                                                                                                                              |
|        |       |      | 1 Frame was aborted due to excessive defer condition. IEVENTGg[EXD] is also set.                                                                                                                                                                                                  |
|        | 10-13 | RC   | Retry Count. Written by the eTSEC.                                                                                                                                                                                                                                                |
|        |       |      | 0 The frame is sent correctly the first time.                                                                                                                                                                                                                                     |
|        |       |      | x One or more attempts where needed to send the transmit frame. If this field is 15, then 15 or more retries were needed. The Ethernet controller updates RC after sending the buffer.                                                                                            |

Table 15-1106. Transmit data buffer descriptor (TxBD) field descriptions (continued)

| Offset | Bits | Name                      | Description                                                                                                                                                                                                                                                                                                                                  |
|--------|------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | 14   | UN                        | Underrun. Written by the eTSEC.                                                                                                                                                                                                                                                                                                              |
|        |      |                           | 0 No underrun encountered (data was retrieved from external memory in time to send a complete frame).                                                                                                                                                                                                                                        |
|        |      |                           | 1 The Ethernet controller encountered a transmitter underrun condition while sending the associated buffer. This could also have occurred in relation to a bus error causing IEVENTGg[EBERR]. The eTSEC terminates the transmission and updates UN.                                                                                          |
|        |      | TOE                       | TCP/IP offload enable. Written by user. Valid only if set in the first BD of a frame.                                                                                                                                                                                                                                                        |
|        |      |                           | 0 No TCP/IP offload acceleration is applied to the frame prior to transmission.                                                                                                                                                                                                                                                              |
|        |      |                           | 1 eTSEC looks for a TOE Frame Control Block preceding the frame, and applies TCP/IP offload acceleration as controlled by the FCB.                                                                                                                                                                                                           |
|        | 15   | TR                        | Truncation. Written by the eTSEC. Set in the last TxBD (TxBD[L] is set) when IEVENTGg[BABT] occurs for a frame (a frame length greater than or equal to the value set in the maximum frame length register is encountered, the HFE bit in the BD is cleared, and MACCFG2[Huge Frame] is cleared). The frame is sent truncated.               |
| 2-3    | 0-15 | Data Length               | Data length is the number of octets the eTSEC should transmit from this BD's data buffer. It is never modified by the eTSEC. This field must be greater than zero, as zero indicates a BD not ready.                                                                                                                                         |
| 4-7    | 0-15 | TX Data Buffer<br>Pointer | The transmit buffer pointer contains the address of the associated data buffer. The data buffer pointer for the first BD of a TxPAL-enabled frame must be aligned on an 8-byte boundary. There are no alignment restrictions for the data buffer pointers of the second or subsequent BDs of a TxPAL-enabled frame, or for non-TxPAL frames. |

## 15.9.8.3 Receive buffer descriptors (RxBD)

In the RxBD the user initializes the E, I, and W bits in the first word and the pointer in second word. If the data buffer is used, the eTSEC modifies the E, L, F, M, BC, MC, LG, NO, CR, OV, and TR bits and writes the length of the used portion of the buffer in the first word.

The M, BC, MC, LG, NO, CR, OV, and TR bits in the first word of the buffer descriptor are only modified by the eTSEC if the L (last BD in frame) bit is set. The first word of the RxBD contains control and status bits. Its formats are detailed below.

The number of buffer descriptors in a ring is set using the W bit to indicate that the next buffer wraps back to the beginning of the ring. See Maximum frame length (eTSEC\_MAXFRM), for information on setting the size of the buffer ring.

Table 15-1107. Receive buffer descriptor

|            | 0 | 1           | 2 | 3 | 4 | 5 | 6 | 7 | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
|------------|---|-------------|---|---|---|---|---|---|----|----|----|----|----|----|----|----|
| Offset + 0 | Е | RO1         | W | ı | L | F | - | М | ВС | МС | LG | NO | SH | CR | OV | TR |
| Offset + 2 |   | DATA LENGTH |   |   |   |   |   |   |    |    |    |    |    |    |    |    |

#### Table 15-1107. Receive buffer descriptor (continued)

| Offset + 4 | RX DATA BUFFER POINTER |
|------------|------------------------|
| Offset + 6 |                        |

The RxBD definition is interpreted by eTSEC hardware as if RxBDs mapped to C data structures in the manner illustrated by the following code.

```
typedef unsigned short uint_16; /* choose 16-bit native type */
typedef unsigned int uint_32; /* choose 32-bit native type */
typedef struct rxbd_struct {
    uint_16 flags;
    uint_16 length;
    uint_32 bufptr;
} rxbd;
```

#### Table 15-1108. Receive buffer descriptor field descriptions

| Offset | Bits | Name | Description                                                                                                                                                                                                                                                                                                       |
|--------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-1    | 0    | E    | Empty, written by the eTSEC (when cleared) and by the user (when set).                                                                                                                                                                                                                                            |
|        |      |      | 0 The data buffer associated with this BD is filled with received data, or data reception is aborted due to an error condition. The status and length fields have been updated as required.                                                                                                                       |
|        |      |      | 1 The data buffer associated with this BD is empty, or reception is currently in progress.                                                                                                                                                                                                                        |
|        | 1    | RO1  | Receive software ownership bit.                                                                                                                                                                                                                                                                                   |
|        |      |      | This field is reserved for use by software. This read/write bit is not modified by hardware, nor does its value affect hardware.                                                                                                                                                                                  |
|        | 2    | W    | Wrap, written by user.                                                                                                                                                                                                                                                                                            |
|        |      |      | 0 The next buffer descriptor is found in the consecutive location.                                                                                                                                                                                                                                                |
|        |      |      | 1 The next buffer descriptor is found at the location defined in RBASE.                                                                                                                                                                                                                                           |
|        | 3    | I    | Interrupt, written by user.                                                                                                                                                                                                                                                                                       |
|        |      |      | 0 No interrupt is generated after this buffer is serviced.                                                                                                                                                                                                                                                        |
|        |      |      | 1 IEVENTGg[RXB] or IEVENTGg[RXF] are set after this buffer is serviced. This bit can cause an interrupt if enabled (IMASKGg[RXBEN] or IMASKGg[RXFEN]). If the user wants to be interrupted only if RXF occurs, then the user must disable RXB (IMASKGg[RXBEN] is cleared) and enable RXF (IMASKGg[RXFEN] is set). |
|        | 4    | L    | Last in frame, written by the eTSEC.                                                                                                                                                                                                                                                                              |
|        |      |      | 0 The buffer is not the last in a frame.                                                                                                                                                                                                                                                                          |
|        |      |      | 1 The buffer is the last in a frame.                                                                                                                                                                                                                                                                              |
|        | 5    | F    | First in frame, written by the eTSEC.                                                                                                                                                                                                                                                                             |
|        |      |      | 0 The buffer is not the first in a frame.                                                                                                                                                                                                                                                                         |
|        |      |      | 1 The buffer is the first in a frame.                                                                                                                                                                                                                                                                             |
|        | 6    | -    | Reserved                                                                                                                                                                                                                                                                                                          |

Table 15-1108. Receive buffer descriptor field descriptions (continued)

| Offset | Bits | Name                      | Description                                                                                                                                                                                                                                                                                                                   |
|--------|------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | 7    | М                         | Miss, written by the eTSEC. (This bit is valid only if the L-bit is set and eTSEC is in promiscuous mode.)                                                                                                                                                                                                                    |
|        |      |                           | This bit is set by the eTSEC for frames that were accepted in promiscuous mode, but were flagged as a "miss" by the internal address recognition; thus, while in promiscuous mode, the user can use the M-bit to quickly determine whether the frame was destined to this station.                                            |
|        |      |                           | 0 The frame was received because of an address recognition hit.                                                                                                                                                                                                                                                               |
|        |      |                           | 1 The frame was received because of promiscuous mode.                                                                                                                                                                                                                                                                         |
|        | 8    | BC                        | Broadcast. Written by the eTSEC. (Only valid if L is set.) Is set if the DA is broadcast (FF-FF-FF-FF-FF).                                                                                                                                                                                                                    |
|        | 9    | MC                        | Multicast. Written by the eTSEC. (Only valid if L is set.) Is set if the DA is multicast and not BC.                                                                                                                                                                                                                          |
|        | 10   | LG                        | Rx frame length violation, written by the eTSEC (only valid if L is set).                                                                                                                                                                                                                                                     |
|        |      |                           | A frame length greater than or equal to the maximum frame length was recognized; in this case LG is set regardless of the setting of MACCFG2[Huge Frame]. If MACCFG2[Huge Frame] is cleared, the frame is truncated to the value programmed in the maximum frame length register. This bit is valid only if the L bit is set. |
|        | 11   | NO                        | Rx non-octet aligned frame, written by the eTSEC (only valid if L is set).                                                                                                                                                                                                                                                    |
|        |      |                           | A frame that contained a number of bits not divisible by eight was received.                                                                                                                                                                                                                                                  |
|        | 12   | SH                        | Short frame, written by the eTSEC (only valid if L is set). A frame length less than the minimum 64B that is defined for ethernet. was recognized, provided RCTRL[RSF] is set.                                                                                                                                                |
|        | 13   | CR                        | Rx CRC error, written by the eTSEC (only valid if L is set).                                                                                                                                                                                                                                                                  |
|        |      |                           | This frame contains a CRC error and is an integral number of octets in length. This bit is also set if a receive code group error is detected.                                                                                                                                                                                |
|        | 14   | OV                        | Overrun, written by the eTSEC (only valid if L is set).                                                                                                                                                                                                                                                                       |
|        |      |                           | A receive FIFO overrun occurred during frame reception. If this bit is set, the other status bits, M, LG, NO, CR and TR lose their normal meaning and are zero.                                                                                                                                                               |
|        | 15   | TR                        | Truncation, written by the eTSEC (only valid if L is set).                                                                                                                                                                                                                                                                    |
|        |      |                           | Set if the receive frame is truncated. This can happen if a frame length greater than the maximum frame length is received and MACCFG2[Huge Frame] is cleared. If this bit is set, the frame must be discarded and the other error bits must be ignored as they may be incorrect.                                             |
| 2-3    | 0-15 | Data Length               | Data length, written by the eTSEC.                                                                                                                                                                                                                                                                                            |
|        |      |                           | Data length is the number of octets written by the eTSEC into this BD's data buffer if L is cleared (the value is equal to MRBLR), or, if L is set, the length of the frame including CRC, FCB (if RCTRL[PRSDEP > 00), preamble (if MACCFG2[PreAmRxEn]=1), time stamp (if RCTRL[TS] = 1) and any padding (RCTRL[PAL]).        |
| 4-7    | 0-15 | RX Data Buffer<br>Pointer | Receive buffer pointer, written by the user.  The receive buffer pointer, which always points to the first location of the associated data buffer, must be 8-byte aligned. For best performance, use 64-byte aligned receive buffer pointer addresses. The buffer must reside in memory external to the eTSEC.                |

# 15.10 Initialization/application information

This section explains interface mode configuration and multigroup mode configuration.

# 15.10.1 Interface mode configuration

This section describes how to configure the eTSEC in different supported interface mode(s):

- MII
- RMII
- RGMII
- SGMII

The following subsections describe the pinout, the data registers that must be initialized, and speed selection options.

## 15.10.1.1 MII interface mode

Table 15-1109. MII interface mode signal configuration

| eTSEC   |     | MII interface  |                    |              |                |
|---------|-----|----------------|--------------------|--------------|----------------|
|         |     |                | Frequency [MHz] 25 |              |                |
|         |     |                | V                  | oltage [V] 3 | .3             |
| Signals | I/O | No. of Signals | Signals            | I/O          | No. of signals |
| GTX_CLK | 0   | 1              | leave unconnected  | •            |                |
| TX_CLK  | I   | 1              | TX_CLK             | I            | 1              |
| TxD[0]  | 0   | 1              | TxD[0]             | 0            | 1              |
| TxD[1]  | 0   | 1              | TxD[1]             | 0            | 1              |
| TxD[2]  | 0   | 1              | TxD[2]             | 0            | 1              |
| TxD[3]  | 0   | 1              | TxD[3]             | 0            | 1              |
| TX_EN   | 0   | 1              | TX_EN              | 0            | 1              |
| TX_ER   | 0   | 1              | TX_ER              | 0            | 1              |
| RX_CLK  | I   | 1              | RX_CLK             | I            | 1              |
| RxD[0]  | I   | 1              | RxD[0]             | I            | 1              |
| RxD[1]  | I   | 1              | RxD[1]             | I            | 1              |
| RxD[2]  | I   | 1              | RxD[2]             | I            | 1              |
| RxD[3]  | I   | 1              | RxD[3]             | I            | 1              |
| RX_DV   | I   | 1              | RX_DV              | I            | 1              |
| RX_ER   | I   | 1              | RX_ER              | I            | 1              |
| COL     | I   | 1              | COL                | I            | 1              |
| CRS     | I   | 1              | CRS                | I            | 1              |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Initialization/application information

## Table 15-1109. MII interface mode signal configuration (continued)

| eTSEC s | MII interface      |                |         |              |                |
|---------|--------------------|----------------|---------|--------------|----------------|
|         | Frequency [MHz] 25 |                |         |              |                |
|         |                    |                | Vol     | tage [V] 3.3 |                |
| Signals | I/O                | No. of Signals | Signals | I/O          | No. of signals |
| Sum     |                    | 25             | Sum     |              | 16             |

#### Table 15-1110. Shared MII signals

| eTSEC signals | I/O | No. of signals | MII signals | I/O | No. of<br>Signals | Function                   |
|---------------|-----|----------------|-------------|-----|-------------------|----------------------------|
| MDIO          | I/O | 1              | MDIO        | I/O | 1                 | Management interface I/O   |
| MDC           | 0   | 1              | MDC         | 0   | 1                 | Management interface clock |
| EC_GTX_CLK125 | I   | 1              | not used    | I   | 0                 | Reference clock            |
| Sum           |     | 3              | Sum         |     | 2                 |                            |

#### Table 15-1111. Mll mode register initialization steps

Set soft\_reset,

MACCFG1[1000\_0000\_0000\_0000\_0000\_0000\_0000]

Clear soft\_reset,

MACCFG1[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize MACCFG2, for MII, half duplex operation.

Set I/F Mode bit,

MACCFG2[0000\_0000\_0000\_0111\_0001\_0000\_0100]

(This example has Full Duplex = 0, Preamble count = 7, PAD/CRC append = 1)

Initialize ECNTRL,

ECNTRL[0000\_0000\_0000\_0001\_0000\_0000]

(This example has Statistics Enable = 1)

Initialize MAC station address,

Set station address to 02\_60\_8C\_87\_65\_43, for example.

Initialize MAC station address,

MACSTNADDR1[0100\_0011\_0110\_0101\_1000\_0111\_1000\_1100]

Set station address to 02\_60\_8C\_87\_65\_43, for example.

Reset the management interface.

MIIMCFG[1000\_0000\_0000\_0000\_0000\_0000\_0111]

Setup the MII mgmt clock speed,

MIIMCFG[0000\_0000\_0000\_0000\_0000\_0000\_0101]

set source clock divide by 14 for example to insure that MDC clock speed is not less than 2.5 MHz

#### Table 15-1111. MII mode register initialization steps (continued)

Read MII Mgmt Indicator register and check for Busy = 0,

This indicates that the eTSEC MII Mgmt bus is idle.

Set up the MII Mgmt for a write cycle to the external PHY Auxiliary Control and Status Register to configure the PHY through the Management interface (overrides configuration signals of the PHY).

MIIMADD[0000\_0000\_0000\_0000\_0000\_0001\_1100]

Perform an MII Mgmt write cycle to the external PHY

Writing to MII Mgmt Control with 16-bit data intended for the external PHY register,

MIIMCON[0000\_0000\_0000\_0000\_0000\_0000\_0100]

Check to see if MII Mgmt write is complete

Read MII Mgmt Indicator register and check for Busy = 0,

 $\mathsf{MIIMIND} \dashrightarrow [0000\_0000\_0000\_0000\_0000\_0000\_0000]$ 

This indicates that the write cycle was completed.

Set up the MII Mgmt for a write cycle to the external PHY Extended PHY control register #1 to set up the interface mode selection.

MIIMADD[0000\_0000\_0000\_0000\_0000\_0001\_0111]

Perform an MII Mgmt write cycle to the external PHY.

Write to MII Mgmt Control with 16-bit data intended for the external PHY register,

MIIMCON[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Check to see if MII Mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

 $\mathsf{MIIMIND} \dashrightarrow [0000\_0000\_0000\_0000\_0000\_0000\_0000]$ 

This indicates that the write cycle was completed.

Set up the MII Mgmt for a write cycle to the external PHY Mode control register to set up the interface mode selection.

MIIMADD[0000 0000 0000 0000 0000 0000 0000]

Perform an MII Mgmt write cycle to the external PHY.

Write to MII Mgmt Control with 16-bit data intended for the external PHY register,

MIIMCON[0000\_0000\_0000\_000u\_00uu\_0uu0\_0000]

where u is user defined based on desired configuration.

Check to see if MII Mgmt write is complete

Read MII Mgmt Indicator register and check for Busy = 0,

 $\mathsf{MIIMIND} \dashrightarrow [0000\_0000\_0000\_0000\_0000\_0000\_0000]$ 

This indicates that the write cycle was completed.

If auto-negotiation was enabled in the PHY, check to see if PHY has completed Auto-Negotiation.

Set up the MII Mgmt for a read cycle to PHY MII Mgmt register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0000\_0000\_0000\_0001]

The PHY Status register is at address 0x1 and in this case the PHY Address is 0x00.

#### Initialization/application information

#### Table 15-1111. Mll mode register initialization steps (continued)

Perform an MII Mgmt read cycle of Status Register.

Clear MIIMCOM[Read Cycle].

Set MIIMCOM[Read Cycle].

(Uses the PHY address (0) and Register address (1) placed in MIIMADD register),

When MIIMIND[BUSY]=0,

read the MIIMSTAT register and check bit 10 (AN Done and Link is up)

MIIMSTAT ---> [0000 0000 0000 0000 0000 0010 0100]

Other information about the link is also returned. (Extend Status, No pre, Remote Fault, An Ability, Link status, extend Ability)

Check auto-negotiation attributes in the PHY as necessary.

Clear IEVENT register,

IEVENT[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize IMASK (Optional)

IMASK[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize MACnADDR1/2 (Optional)

MACnADDR1/2[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize GADDRn (Optional)

GADDRn[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize RCTRL (Optional)

RCTRL[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize DMACTRL (Optional)

DMACTRL[0000 0000 0000 0000 0000 0000 0000]

Initialize (Empty) Transmit Descriptor ring and fill buffers with Data

Initialize TBASE0-TBASE7,

TBASE0-TBASE7[LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_L000]

Initialize (Empty) Receive Descriptor ring and fill with empty buffers

Initialize RBASE0-RBASE7,

RBASE0-RBASE7[LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_L000]

**Enable Transmit Queues Initialize TQUEUE** 

Enable Receive Queues Initialize RQUEUE

Enable Rx and Tx.

MACCFG1[0000\_0000\_0000\_0000\_0000\_0000\_0101]

# 15.10.1.2 RMII interface mode

The table below shows the signals configurations required for RMII interface mode.

Table 15-1112. RMII interface mode signal configuration

| eTSI    | EC signals |                | RMII interface             |              |   |  |
|---------|------------|----------------|----------------------------|--------------|---|--|
|         |            |                | Freque                     | ncy [MHz] 50 |   |  |
|         |            |                | Voltage [V] 3.3            |              |   |  |
| Signals | I/O        | No. of Signals | Signals I/O No. of Signals |              |   |  |
| GTX_CLK | 0          | 1              | leave u                    | unconnected  |   |  |
| TX_CLK  | I          | 1              | REF_CLK                    | I            | 1 |  |
| TxD[0]  | 0          | 1              | TxD[0]                     | 0            | 1 |  |
| TxD[1]  | 0          | 1              | TxD[1]                     | 0            | 1 |  |
| TxD[2]  | 0          | 1              | leave unconnected          |              |   |  |
| TxD[3]  | 0          | 1              | leave unconnected          |              |   |  |
| TX_EN   | 0          | 1              | TX_EN O 1                  |              | 1 |  |
| TX_ER   | 0          | 1              | leave ι                    | unconnected  |   |  |
| RX_CLK  | I          | 1              | leave unconnected          |              |   |  |
| RxD[0]  | I          | 1              | RxD[0]                     | I            | 1 |  |
| RxD[1]  | I          | 1              | RxD[1]                     | I            | 1 |  |
| RxD[2]  | I          | 1              | no                         | ot used      |   |  |
| RxD[3]  | I          | 1              | no                         | ot used      |   |  |
| RX_DV   | I          | 1              | CRS_DV I 1                 |              | 1 |  |
| RX_ER   | I          | 1              | RX_ER I                    |              | 1 |  |
| COL     | I          | 1              | not used                   |              |   |  |
| CRS     | I          | 1              | not used                   |              |   |  |
| Sum     |            | 25             | Sum                        |              | 8 |  |

The table below describes the shared signals for the RMII interface.

Table 15-1113. Shared RMII signals

| eTSEC signals | I/O | No. of signals | RMII signals | I/O | No. of signals | Function                   |
|---------------|-----|----------------|--------------|-----|----------------|----------------------------|
| MDIO          | I/O | 1              | MDIO         | I/O | 1              | Management interface I/O   |
| MDC           | 0   | 1              | MDC          | 0   | 1              | Management interface clock |
| TX_CLK        | ı   | 1              | REF_CLK      | I   | 1              | Reference clock            |
| Sum           |     | 3              | Sum          |     | 3              |                            |

The table below describes the register initializations required to configure the eTSEC in RMII mode.

#### Table 15-1114. RMII mode register initialization steps

Set soft\_reset,

MACCFG1[1000\_0000\_0000\_0000\_0000\_0000\_0000]

Clear soft\_reset,

MACCFG1[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize MACCFG2,

MACCFG2[0000\_0000\_0000\_0111\_0001\_0000\_0101]

(I/F Mode = 1, Full Duplex = 1)

Initialize ECNTRL,

ECNTRL[0000\_0000\_0000\_0001\_0000\_0001\_0000]

(Used to setup Reduced-Pin mode = 1, and TBIM = 0, statistics enable = 1)

Initialize MAC station address

MACSTNADDR2[0110\_0000\_0000\_0010\_0000\_0000\_0000]

to 02608C:876543 for example

Initialize MAC station address

MACSTNADDR1[0100\_0011\_0110\_0101\_1000\_0111\_1000\_1100]

to 02608C:876543 for example

Setup the MII Mgmt clock speed,

MIIMCFG[0000\_0000\_0000\_0000\_0000\_0000\_1101]

set system clock divide by 14 for example to insure that MDC clock speed = < 2.5 MHz

Read MII mgmt indicator register and check for busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the eTSEC MII Mgmt bus is idle.

Set up the MII mgmt for a write cycle to external the PHY AN advertisement register (write the PHY address and register address).

MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0100]

The AN advertisement register is at offset address 0x04 from the external PHY address. (in this case 0x11)

Perform an MII mgmt write cycle to the external PHY.

Write to MII mgmt control with 16-bit data intended for the external PHY AN advertisement register,

Where u must be selected by the user for proper system configuration.

Check to see if MII mgmt write is complete.

Read MII Mgmt indicator register and check for busy = 0,

This indicates that the write cycle was completed.

Set up the MII mgmt for a write cycle to the external PHY Control register (write the PHY address and register address),

MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0000]

The control register is at offset address 0x00 from the external PHY address. (in this case 0x11)

#### Table 15-1114. RMII mode register initialization steps (continued)

Perform an MII mgmt write cycle to the external PHY.

Write to MII mgmt control with 16-bit data intended for the external PHY control register,

MIIMCON[0000\_0000\_0000\_0001\_0010\_0000\_0000]

This enables the external PHY to restart Auto-Negotiations using the configuration set in the AN Advertisement register.

Check to see if MII Mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

 $\mathsf{MIIMIND} \dashrightarrow [0000\_0000\_0000\_0000\_0000\_0000\_0000]$ 

This indicates that the write cycle was completed.

Check to see if PHY has completed Auto-Negotiation.

Set up the MII Mgmt for a read cycle to the PHY MII Mgmt register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0000\_0010\_0000\_0001]

The PHY Status register is at address 0x1 and in this case the PHY Address is 0x2.

Perform an MII Mgmt read cycle of Status Register.

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (2) and Register address (1) placed in MIIMADD register)

When MIIMIND[BUSY]=0,

read the MIIMSTAT register and check bit 10. (AN Done)

MIIMSTAT ---> [0000 0000 0000 0000 0000 0000 0010 0000]

Other information about the link is also returned. (Extend Status, No pre, Remote Fault, An Ability, Link status, extend Ability)

Perform an MII Mgmt read cycle of AN Expansion Register.

Setup MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0110]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x11) and Register address (6) placed in MIIMADD register)

When MIMIND[BUSY]=0,

read the MII Mgmt AN Expansion register and check bits 13 and 14. (NP Able and Page Rx'd)

MII Mgmt AN Expansion ---> [0000\_0000\_0000\_0000\_0000\_0000\_0110]

Perform an MII Mgmt read cycle of AN Link Partner Base Page Ability Register. (Optional)

Setup MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0101]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x11) and Register address (5) placed in MIIMADD register)

When MIIMIND[BUSY]=0,

read the MII mgmt AN link partner base page ability register and check bits 9 and 10. (Half and Full Duplex)

MII mgmt AN link partner base page ability ---> [0000\_0000\_0000\_0000\_0000\_000x\_x110\_0000]

Setting up the MII Mgmt for a write cycle to TBI MII mgmt register (write the TBI's address and Register address),

MIIMADD[0000\_0000\_0000\_0000\_0001\_0000\_0000\_1011]

the TBI control register is at offset address 0x11 from TBIPA

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Table 15-1114. RMII mode register initialization steps (continued)

Perform an MII mgmt write cycle

Writing to MII mgmt control with 16-bit data intended for TBI's MII mgmt control register (TBI control),

MIIMCON[0000\_0000\_0000\_0000\_0010\_0001\_0000]

This configures the TBI control to GMII mode and AN sense

Check to see if MII mgmt write is complete

Read MII mgmt indicator register and check for busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicate that the write cycle was completed

Perform an MII mgmt read cycle (Optional)

Set MIIMCOM[read cycle]

(Uses the TBI address and register address placed in MIIMADD register),

read the MIIMSTAT register and verify that

MIIMSTAT ---> [0000\_0000\_0000\_0000\_0010\_0001\_0000]

Check to see if PHY has completed Auto-Negotiation

Setting up the MII mgmt for a read cycle to PHY's MII mgmt register (write the PHY's address and Register address),

MIIMADD[0000\_0000\_0000\_0000\_0010\_0000\_0010]

the PHY status control register is at address 0x2 and lets say the PHY address is 0x2

Perform an MII mgmt read cycle of status register

Set MIIMCOM[read cycle]

(Uses the PHY address (2) and register address (2) placed in MIIMADD register),

read the MIIMSTAT register and check bit 10 (AN done)

MIIMSTAT ---> [0000\_0000\_0000\_0000\_0000\_0010\_0000]

other information about the link is also returned (extend status, no pre, remote fault, an ability, link status, extend ability)

Perform an MII mgmt read cycle of AN expansion Register

MIIMADD[0000\_0000\_0000\_0000\_0010\_0000\_0110]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (2) and Register address (6) placed in MIIMADD register),

read the MII mgmt AN expansion register and check bits 13 and 14 (NP Able and Page Rx'd)

MII Mgmt AN expansion ---> [0000\_0000\_0000\_0000\_0000\_0000\_0110]

Perform an MII mgmt read cycle of AN link partner base page ability register (optional)

MIIMADD[0000\_0000\_0000\_0000\_0010\_0000\_0101]

Set MIIMCOM[read cycle]

(Uses the PHY address (2) and register address (5) placed in MIIMADD register),

read the MII mgmt AN link partner base page ability register and check bits 9 and 10 (half and full duplex)

MII mgmt AN link partner base page ability ---> [0000 0000 0000 0000 0000 00X 1110 0000]

Clear IEVENT register,

IEVENT[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize IMASK (Optional)

IMASK[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## Table 15-1114. RMII mode register initialization steps (continued)

| Initialize GADDRn (Optional)                                           |
|------------------------------------------------------------------------|
| GADDRn[0000_0000_0000_0000_0000_0000]                                  |
| Initialize RCTRL (Optional)                                            |
| RCTRL[0000_0000_0000_0000_0000_0000]                                   |
| Initialize DMACTRL (Optional)                                          |
| DMACTRL[0000_0000_0000_0000_0000_0000_0000]                            |
| Initialize (empty) transmit descriptor ring and fill buffers with data |
| Initialize TBASE0-TBASE7,                                              |
| TBASE0-TBASE7[LLLL_LLLL_LLLL_LLLL_LLLL_LLLL_L000]                      |
| Initialize (empty) receive descriptor ring and fill with empty buffers |
| Initialize RBASE0-RBASE7,                                              |
| RBASE0-RBASE7[LLLL_LLLL_LLLL_LLLL_LLLL_LLLL_L000]                      |
| Enable transmit queues initialize TQUEUE                               |
| Enable receive queues initialize RQUEUE                                |
| Enable Rx and Tx,                                                      |
| MACCFG1[0000_0000_0000_0000_0000_0000_0101]                            |
|                                                                        |

## 15.10.1.3 RGMII interface mode

The table below shows the signal configurations required for RGMII interface mode.

Table 15-1115. RGMII interface mode signal configuration

| eTSEC   | signals |                | RGMII i               | nterface |                |  |
|---------|---------|----------------|-----------------------|----------|----------------|--|
|         |         |                | Frequency [MHz] 125   |          |                |  |
|         |         |                | Voltage [V] 2.5       |          |                |  |
| Signals | I/O     | No. of signals | Signals               | I/O      | No. of signals |  |
| GTX_CLK | 0       | 1              | GTX_CLK               | 0        | 1              |  |
| TX_CLK  | I       | 1              | not u                 | used     |                |  |
| TxD[0]  | 0       | 1              | TxD[0] O              |          | 1              |  |
| TxD[1]  | 0       | 1              | TxD[1]                | 0        | 1              |  |
| TxD[2]  | 0       | 1              | TxD[2]                | 0        | 1              |  |
| TxD[3]  | 0       | 1              | TxD[3]                | 0        | 1              |  |
| TX_EN   | 0       | 1              | TX_CTL (TX_EN/TX_ERR) | 0        | 1              |  |
| TX_ER   | 0       | 1              | leave und             | onnected |                |  |
| RX_CLK  | I       | 1              | RX_CLK I 1            |          | 1              |  |
| RxD[0]  | ı       | 1              | RxD[0] I 1            |          | 1              |  |
| RxD[1]  | I       | 1              | RxD[1] I 1            |          | 1              |  |
| RxD[2]  | I       | 1              | RxD[2]                | I        | 1              |  |

Table 15-1115. RGMII interface mode signal configuration (continued)

| eTSE    | C signals |                | RGMII interface           |     |                |  |  |
|---------|-----------|----------------|---------------------------|-----|----------------|--|--|
|         |           |                | Frequency [MHz] 125       |     |                |  |  |
|         |           |                | Voltage [V] 2.5           |     |                |  |  |
| Signals | I/O       | No. of signals | Signals                   | I/O | No. of signals |  |  |
| RxD[3]  | I         | 1              | RxD[3] I 1                |     | 1              |  |  |
| RX_DV   | I         | 1              | RX_CTL (RX_DV/RX_ERR) I 1 |     | 1              |  |  |
| RX_ER   | I         | 1              | not used                  |     |                |  |  |
| COL     | I         | 1              | not used                  |     |                |  |  |
| CRS     | I         | 1              | not used                  |     |                |  |  |
| Sum     |           | 25             | <b>Sum</b> 12             |     |                |  |  |

Table 15-1116. Shared RGMII signals

| eTSEC signals | I/O | No. of signal s | GMII signals | I/O | No. of signal s | Function                   |
|---------------|-----|-----------------|--------------|-----|-----------------|----------------------------|
| MDIO          | I/O | 1               | MDIO         | I/O | 1               | Management interface I/O   |
| MDC           | 0   | 1               | MDC          | 0   | 1               | Management interface clock |
| EC_GTX_CLK125 | I   | 1               | GTX_CLK125   | I   | 1               | Reference clock            |
| Sum           |     | 3               | Sum          | •   | 3               | -                          |

The following table describes the register initializations required to configure the eTSEC in RGMII mode.

Table 15-1117. RGMII mode register initialization steps

| Set soft_reset,                                             |
|-------------------------------------------------------------|
| MACCFG1[1000_0000_0000_0000_0000_0000_0000]                 |
| Clear soft_reset,                                           |
| MACCFG1[0000_0000_0000_0000_0000_0000_0000]                 |
| Initialize MACCFG2,                                         |
| MACCFG2[0000_0000_0000_0111_0010_0000_0101]                 |
| (I/F Mode = 2, Full Duplex = 1)                             |
| Initialize ECNTRL,                                          |
| ECNTRL[0000_0000_0000_0001_0000_0000_0000]                  |
| (This example has RGMII 10Mbps mode, statistics enable = 1) |
| Initialize MAC station address,                             |
| MACSTNADDR2[0110_0000_0000_0010_0000_0000_0000]             |
| to 02608C:876543, for example.                              |

#### Table 15-1117. RGMII mode register initialization steps (continued)

Initialize MAC station address,

MACSTNADDR1[0100\_0011\_0110\_0101\_1000\_0111\_1000\_1100]

to 02608C:876543, for example.

Setup the MII Mgmt clock speed,

MIIMCFG[0000 0000 0000 0000 0000 0000 0101]

Set source clock divide by 14, for example, to insure that TSEC\_MDC clock speed is not less than 2.5 MHz.

Read MII mgmt indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the eTSEC MII Mgmt bus is idle.

Set up the MII mgmt for a write cycle to external the PHY AN Advertisement register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0100]

The AN Advertisement register is at offset address 0x04 from the external PHY address. (in this case 0x11)

Perform an MII mgmt write cycle to the external PHY.

Write to MII mgmt control with 16-bit data intended for the external PHY AN Advertisement register,

MIIMCON[0000\_0000\_0000\_u0uu\_uuuu\_uuuu\_uuuu]

Where u must be selected by the user for proper system configuration.

Check to see if MII mgmt write is complete.

Read MII mgmt Indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the write cycle was completed.

Set up the MII mgmt for a write cycle to the external PHY Control register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0000]

The control register (CR) is at offset address 0x00 from the external PHY address. (in this case 0x11)

Perform an MII mgmt write cycle to the external PHY.

Write to MII mgmt Control with 16-bit data intended for the external PHY Control register,

MIIMCON[0000\_0000\_0000\_0001\_0010\_0000\_0000]

This enables the external PHY to restart Auto-Negotiations using the configuration set in the AN Advertisement register.

Check to see if MII mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

This indicates that the write cycle was completed.

Check to see if PHY has completed Auto-Negotiation.

Set up the MII Mgmt for a read cycle to the PHY MII Mgmt register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0000\_0010\_0000\_001]

The PHY Status register is at address 0x1 and in this case the PHY Address is 0x2.

#### Table 15-1117. RGMII mode register initialization steps (continued)

Perform an MII Mgmt read cycle of Status Register.

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (2) and Register address (2) placed in MIIMADD register)

When MIIMIND[BUSY]=0,

read the MIIMSTAT register and check bit 10. (AN Done)

MIIMSTAT ---> [0000\_0000\_0000\_0000\_0000\_0010\_0000]

Other information about the link is also returned. (Extend Status, No pre, Remote Fault, An Ability, Link status, extend Ability)

Perform an MII Mgmt read cycle of AN Expansion Register.

Setup MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0110]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x11) and Register address (6) placed in MIIMADD register)

When MIIMIND[BUSY]=0,

read the MII Mgmt AN Expansion register and check bits 13 and 14. (NP Able and Page Rx'd)

MII Mgmt AN Expansion ---> [0000\_0000\_0000\_0000\_0000\_0000\_0110]

Perform an MII Mgmt read cycle of AN Link Partner Base Page Ability Register. (Optional)

Setup MIIMADD[0000\_0000\_0000\_0001\_0001\_0000\_0101]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x11) and Register address (5) placed in MIIMADD register)

When MIIMIND[BUSY]=0,

read the MII Mgmt AN Link Partner Base Page Ability register and check bits 9 and 10. (Half and Full Duplex)

MII Mgmt AN Link Partner Base Page Ability ---> [0000 0000 0000 0000 0000 1x10 0000]

Clear IEVENT register,

Initialize IMASK (Optional)

IMASK[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize MACnADDR1/2 (Optional)

MACnADDR1/2[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize GADDRn (Optional)

GADDRn[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize RCTRL (Optional)

RCTRL[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize DMACTRL (Optional)

Initialize (Empty) Transmit Descriptor ring and fill buffers with Data

Initialize TBASE0-TBASE7,

TBASE0-TBASE7[LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_L000]

#### Table 15-1117. RGMII mode register initialization steps (continued)

| Initialize (Empty) Receive Descriptor ring and fill with empty buffers |  |  |  |  |  |
|------------------------------------------------------------------------|--|--|--|--|--|
| Initialize RBASE0-RBASE7,                                              |  |  |  |  |  |
| RBASE0-RBASE7[LLLL_LLLL_LLLL_LLLL_LLLL_LLLL_L000]                      |  |  |  |  |  |
| Enable Transmit Queues Initialize TQUEUE                               |  |  |  |  |  |
| Enable Receive Queues Initialize RQUEUE                                |  |  |  |  |  |
| Enable Rx and Tx,                                                      |  |  |  |  |  |
| MACCFG1[0000_0000_0000_0000_0000_0000_0101]                            |  |  |  |  |  |

## 15.10.1.4 SGMII interface support

## Table 15-1118. SGMII interface signal configuration (4-wire)

| SerDes Signals       |     |                | SGMII Interface      |     |                |
|----------------------|-----|----------------|----------------------|-----|----------------|
| Frequency [MHz] 1250 |     |                | Frequency [MHz] 1250 |     |                |
| Voltage [V] LVDS     |     |                | Voltage [V] LVDS     |     |                |
| Signals              | I/O | No. of Signals | Signals              | I/O | No. of Signals |
| TXn/TXn              | 0   | 2              | TXD                  | 0   | 2              |
| RXn/RXn              | 1   | 2              | RXD                  | I   | 2              |
| Sum 4                |     | 4              | Sum                  |     | 4              |

SGMII mode initialization sequence requires additional initialization for the SerDes.

#### **NOTE**

SGMII mode utilizes the internal TBI PHY. The internal TBI PHY only auto-negotiates at 1 Gbps. However, 10 Mbps and 100 Mbps speeds are supported in SGMII mode. It is recommended that the external PHY inform the MAC if the desired link speed is not 1 Gbps. Software can perform MII management cycles to determine the external PHY link speed and program ECNTRL and MACCFG2 accordingly.

### Table 15-1119. SGMII mode register initialization steps

Initialize SerDes to select SGMII. The initialization sequence should be prepended with SerDes initialization.

Set Soft\_Reset,

MACCFG1[1000\_0000\_0000\_0000\_0000\_0000\_0000]

Clear Soft\_Reset,

MACCFG1[0000\_0000\_0000\_0000\_0000\_0000]

#### Initialization/application information

#### Table 15-1119. SGMII mode register initialization steps (continued)

Initialize MACCFG2,

MACCFG2[0000\_0000\_0000\_0000\_0111\_0010\_0000\_0101]

(I/F Mode = 2, Full Duplex = 1)

(Set I/F mode = 1 in SGMII 10/100 Mbps speed)

Initialize ECNTRL,

ECNTRL[0000\_0000\_0000\_0001\_0000\_0010\_0010]

(This example has Statistics Enable = 1, TBIM = 1, SGMIIM = 1)

(Set R100M = 1 in SGMII 100 Mbps speed)

Initialize MAC Station Address

to 02608C:876543, for example.

Initialize MAC Station Address

MACSTNADDR1[0100\_0011\_0110\_0101\_1000\_0111\_1000\_1100]

to 02608C:876543, for example.

Assign a Physical address to the TBI,

TBIPA[0000\_0000\_0000\_0000\_0000\_0000\_0001\_0000]

set to 16, for example.

Setup the MII Mgmt clock speed,

MIIMCFG[0000\_0000\_0000\_0000\_0000\_0000\_0101]

set source clock divide by 14 for example to insure that MDC clock speed is not less than 2.5 MHz

Read MII Mgmt Indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the eTSEC MII Mgmt bus is idle.

Set up the MII Mgmt for a read cycle to TBI's Control register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0000\_0000]

the control register (CR) is at offset address 0x00 from the TBI's address.

Perform an MII Mgmt read cycle to verify state of TBI Control Register (optional)

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the TBI address and Register address placed in MIIMADD register),

When MIMIND[BUSY] = 0,

read the MIIMSTAT and look for AN Enable and other bit information.

Set up the MII Mgmt for a write cycle to TBICON register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0000\_0001\_0001]

The TBICON register is at offset address 0x11 from the TBI's address.

#### Table 15-1119. SGMII mode register initialization steps (continued)

Perform an MII Mgmt write cycle to TBI.

Writing to MII Mgmt Control with 16-bit data intended for TBICON register,

MIIMCON[0000\_0000\_0000\_0000\_0000\_0010\_0000]

This sets TBI in single clock mode and MII Mode off to enable communication with SerDes.

Check to see if MII Mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the write cycle was completed.

Set up the MII Mgmt for a write cycle to TBI's AN Advertisement register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0000\_0000\_0100]

The AN Advertisement register is at offset address 0x04 from the TBI's address.

Perform an MII Mgmt write cycle to TBI.

Writing to MII Mgmt Control with 16-bit data intended for TBI's AN Advertisement register,

MIIMCON[0000 0000 0000 0000 0001 1010 0000]

This advertises to the Link Partner that the TBI supports PAUSE and Full Duplex mode and does not support Half Duplex mode.

Check to see if MII Mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the write cycle was completed.

Additional SerDes setup as required

Set up the MII Mgmt for a write cycle to TBI's Control register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0000\_0000]

the control register (CR) is at offset address 0x00 from the TBI's address.

Perform an MII Mgmt write cycle to TBI.

Writing to MII Mgmt Control with 16-bit data intended for TBI's Control register,

MIIMCON[0000\_0000\_0000\_0001\_0011\_0100\_0000]

This enables the TBI to restart Auto-Negotiations using the configuration set in the AN Advertisement register.

Check to see if MII Mgmt write is complete.

Read MII Mgmt Indicator register and check for Busy = 0,

MIIMIND ---> [0000\_0000\_0000\_0000\_0000\_0000\_0000]

This indicates that the write cycle was completed.

Check to see if PHY has completed Auto-Negotiation.

Set up the MII Mgmt for a read cycle to PHY MII Mgmt register (write the PHY address and Register address),

MIIMADD[0000\_0000\_0000\_0001\_0000\_0001]

The PHY Status control register is at address 0x1 and in this case the PHY Address is 0x10.

#### Initialization/application information

#### Table 15-1119. SGMII mode register initialization steps (continued)

Perform an MII Mgmt read cycle of Status Register.

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (2) and Register address (2) placed in MIIMADD register),

When MIMIND[BUSY] = 0,

read the MIIMSTAT register and check bit 10 (AN Done)

MII Mgmt AN Expansion ---> [0000\_0000\_0000\_0000\_0000\_0000\_0110]

Other information about the link is also returned. (Extend Status, No pre, Remote Fault, An Ability, Link status, extend Ability)

Perform an MII Mgmt read cycle of AN Expansion Register.

Setup MIIMADD[0000\_0000\_0000\_0001\_0000\_0000\_0110]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x10) and Register address (6) placed in MIIMADD register),

When MIMIND[BUSY] = 0,

read the MII Mgmt AN Expansion register and check bits 13 and 14 (NP Able and Page Rx'd)

MII Mgmt AN Expansion ---> [0000\_0000\_0000\_0000\_0000\_0000\_0110]

Perform an MII Mgmt read cycle of AN Link Partner Base Page Ability Register. (Optional)

Setup MIIMADD[0000\_0000\_0000\_0001\_0000\_0000\_0101]

Clear MIIMCOM[Read Cycle]

Set MIIMCOM[Read Cycle]

(Uses the PHY address (0x10) and Register address (5) placed in MIIMADD register),

When MIMIND[BUSY] = 0,

read the MII Mgmt AN Link Partner Base Page Ability register and check bits 9 and 10. (Half and Full Duplex)

MII Mgmt AN Link Partner Base Page Ability ---> [0000 0000 0000 0000 0000 1110 0000]

Clear IEVENT register,

IEVENT[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize IMASK (Optional)

IMASK[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize MACnADDR1/2 (Optional)

MACnADDR1/2[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize GADDRn (Optional)

GADDRn[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize RCTRL (Optional)

RCTRL[0000\_0000\_0000\_0000\_0000\_0000\_0000]

Initialize DMACTRL (Optional)

DMACTRL[0000 0000 0000 0000 0000 0000 0000]

Initialize (Empty) Transmit Descriptor ring and fill buffers with Data

Initialize TBASE0-TBASE7,

TBASE0-TBASE7[LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LL000]

#### Table 15-1119. SGMII mode register initialization steps (continued)

Initialize (Empty) Receive Descriptor ring and fill with empty buffers

Initialize RBASE0-RBASE7,

RBASE0-RBASE7[LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_LLLL\_L000]

Enable Transmit Queues Initialize TQUEUE

Enable Receive Queues Initialize RQUEUE

Enable Rx and Tx,

MACCFG1[0000\_0000\_0000\_0000\_0000\_0000\_0101]

## 15.10.2 Multigroup mode initialization

To operate eTSEC in multigroup mode, the following configuration sequence must be performed before any code initializes a per-group register (IEVENTGg, IMASKGg, IEVENTM, IMASKM, TSTAT, RSTAT) and before Rx and Tx are enabled.

In default single-group mode, only group 0 is active.

- 1. Set ISRG0 with a 1 in every RRm for every Rx ring to be associated with group 0.
- 2. Set ISRG0 with a 1 in every TRm for every Tx ring to be associated with group 0. Steps 1 and 2 may be done with a single write.
- 3. Set ISRG1 with a 1 in every RRm for every Rx ring to be associated with group 1.
- 4. Set ISRG1 with a 1 in every TRm for every Tx ring to be associated with group 1. Steps 3 and 4 may be done with a single write.

Initialization/application information

# Chapter 16 Enhanced secure digital host controller (eSDHC)

The enhanced secure digital host controller (eSDHC) provides an interface between the host system and these types of memory cards.

## 16.1 eSDHC overview

The enhanced secure digital host controller (eSDHC) provides an interface between the host system and these types of memory cards:

MultiMediaCard (MMC)

MMC is a universal low-cost data storage and communication medium designed to cover a wide area of applications including mobile video and gaming, which are available from either pre-loaded MMC cards or downloadable from cellular phones, WLAN, or other wireless networks. Old MMC cards are based on a seven-pin serial bus with a single data pin, while the new high-speed MMC communication is based on an advanced 11-pin serial bus designed to operate in a low voltage range.

• Secure digital (SD) card

The secure digital (SD) card is an evolution of old MMC technology. It is specifically designed to meet the security, capacity, performance, and environment requirements inherent in the emerging audio and video consumer electronic devices. The physical form factor, pin assignments, and data transfer protocol are forward-compatible with the old MMC.

The eSDHC acts as a bridge, passing host bus transactions to SD/MMC cards by sending commands and performing data accesses to or from the cards. It handles the SD/MMC protocol at the transmission level.



Figure 16-1. System connection of the eSDHC

This figure shows the eSDHC block diagram.



Figure 16-2. eSDHC block diagram

# 16.2 eSDHC features summary

The eSDHC includes the following features:

• Compatible with the following specifications:

#### eSDHC external signal description

- SD Host Controller Standard Specification, Version 2.0 (http://www.sdcard.org) with test event register support
- MultiMediaCard System Specification, Version 4.2 (http://www.mmca.org)
- SD Memory Card Specification, Version 2.0 (http://www.sdcard.org)
- Designed to work with SD Memory, SDHC memory, miniSD Memory, MMC, MMCplus, and RS-MMC cards
- Card bus clock frequency up to 52 MHz
- Supports 1-/4-bit SD mode, 1-/4-/8-bit MMC modes
  - Up to 200 Mbps data transfer for SD/MMC cards using four parallel data lines
  - Up to 416 Mbps data transfer for MMC using 8 parallel data lines
- Single- and multi-block read and write
- Write-protection switch for write operations
- Synchronous abort
- Pause during the data transfer at a block gap
- Auto CMD12 for multi-block transfer
- Host can initiate non-data transfer commands while the data transfer is in progress
- Fully configurable 128 x 32-bit FIFO for read/write data
- Internal DMA capabilities
- Supports booting from eSDHC. See eSDHC boot for more detailed information

## 16.2.1 Data transfer modes

The eSDHC can select the following modes for data transfer:

- SD 1-bit
- SD 4-bit
- MMC 1-bit
- MMC 4-bit
- MMC 8-bit
- Identification mode (up to 400 kHz)
- MMC full-speed mode (up to 20 MHz)
- MMC high-speed mode (up to 52 MHz)
- SD full-speed mode (up to 25 MHz)
- SD high-speed mode (up to 50 MHz)

# 16.3 eSDHC external signal description

The eSDHC has 12 chip I/O signals.

• SDHC\_CLK is the internally generated clock signal that drives the MMC or SD card.

- SDHC\_CMD I/O sends commands and receives responses from the card.
- SDHC\_DAT7 -SDHC\_DAT0 perform data transfers between the eSDHC and the card. If the eSDHC is desired to support a 4-bit data transfer, SDHC\_DAT7-SDHC\_DAT4 can also be optional and tied high.
- SDHC\_CD\_B and SDHC\_WP are card detection and write protection signals from the socket.

Table 16-1. Signal properties

| Name      | Port | Function                                                                            | Reset State    | Pull up/Pull down Required                |
|-----------|------|-------------------------------------------------------------------------------------|----------------|-------------------------------------------|
| SDHC_CLK  | 0    | Clock for MMC/SD card                                                               | 0              | N/A                                       |
| SDHC_CMD  | I/O  | Command line to card                                                                | High impedance | Pull up                                   |
| SDHC_DAT7 | I/O  | 8-bit mode: DAT7 line not used in other modes                                       | High impedance | Pull up                                   |
| SDHC_DAT6 | I/O  | 8-bit mode: DAT6 line not used in other modes                                       | High impedance | Pull up                                   |
| SDHC_DAT5 | I/O  | 8-bit mode: DAT5 line not used in other modes                                       | High impedance | Pull up                                   |
| SDHC_DAT4 | I/O  | 8-bit mode: DAT4 line in not used in other modes                                    | High impedance | Pull up                                   |
| SDHC_DAT3 | I/O  | 4-/8-bit mode: DAT3 line                                                            | High impedance | Pull up. Do not use DAT3 pin as a CD pin. |
| SDHC_DAT2 | I/O  | 4-/8-bit mode: DAT2 line                                                            | High impedance | Pull up                                   |
| SDHC_DAT1 | I/O  | 8-bit mode: DAT1 line 4-bit mode: DAT1 line                                         | High impedance | Pull up                                   |
| SDHC_DAT0 | I/O  | 8-bit mode: DAT0 line 4-bit mode: DAT0 line                                         | High impedance | Pull up                                   |
| SDHC_CD_B | I    | Card detection pin; if not used, tied high. Low: Card present High: No card present | N/A            | N/A                                       |
| SDHC_WP   | I    | Card write protect detect; if not used, tied low                                    | N/A            | N/A                                       |

The table below shows the memory mapped registers of the eSDHC module and their offsets. It lists the offset, name, and a cross-reference to the complete description of each register. Note that the full register address is comprised of CCSRBAR together with the eSDHC block base address and offset listed in the following table. Undefined 4-byte address spaces within offset 0x0000-0xFFFF are reserved.

#### NOTE

All eSDHC registers must be accessed as aligned 4-byte quantities. Accesses to the eSDHC registers that are less than 4-bytes are not supported.

### eSDHC memory map

| Offset address (hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_E000               | DMA system address (eSDHC_DSADDR)               | 32                 | R/W    | 0000_0000h  | 16.4.1/1195      |
| 2_E004               | Block attributes (eSDHC_BLKATTR)                | 32                 | R/W    | 0001_0000h  | 16.4.2/1195      |
| 2_E008               | Command argument (eSDHC_CMDARG)                 | 32                 | R/W    | 0000_0000h  | 16.4.3/1196      |
| 2_E00C               | Command transfer type (eSDHC_XFERTYP)           | 32                 | R/W    | 0000_0000h  | 16.4.4/1197      |
| 2_E010               | Command response n (eSDHC_CMDRSP0)              | 32                 | R      | 0000_0000h  | 16.4.5/1200      |
| 2_E014               | Command response n (eSDHC_CMDRSP1)              | 32                 | R      | 0000_0000h  | 16.4.5/1200      |
| 2_E018               | Command response n (eSDHC_CMDRSP2)              | 32                 | R      | 0000_0000h  | 16.4.5/1200      |
| 2_E01C               | Command response n (eSDHC_CMDRSP3)              | 32                 | R      | 0000_0000h  | 16.4.5/1200      |
| 2_E020               | Data buffer access port (eSDHC_DATPORT)         | 32                 | R/W    | 0000_0000h  | 16.4.6/1201      |
| 2_E024               | Present state (eSDHC_PRSSTAT)                   | 32                 | R      | See section | 16.4.7/1202      |
| 2_E028               | Protocol control (eSDHC_PROCTL)                 | 32                 | R/W    | 0000_0020h  | 16.4.8/1207      |
| 2_E02C               | System control (eSDHC_SYSCTL)                   | 32                 | R/W    | 0000_8008h  | 16.4.9/1210      |
| 2_E030               | Interrupt status (eSDHC_IRQSTAT)                | 32                 | R/W    | 0000_0000h  | 16.4.10/<br>1213 |
| 2_E034               | Interrupt status enable (eSDHC_IRQSTATEN)       | 32                 | R/W    | 117F_013Fh  | 16.4.11/<br>1217 |
| 2_E038               | Interrupt signal enable (eSDHC_IRQSIGEN)        | 32                 | R/W    | 0000_0000h  | 16.4.12/<br>1220 |
| 2_E03C               | Auto CMD12 status (eSDHC_AUTOC12ERR)            | 32                 | R      | 0000_0000h  | 16.4.13/<br>1222 |
| 2_E040               | Host controller capabilities (eSDHC_HOSTCAPBLT) | 32                 | R      | 05F3_0000h  | 16.4.14/<br>1226 |
| 2_E044               | Watermark level (eSDHC_WML)                     | 32                 | R/W    | 1010_1010h  | 16.4.15/<br>1228 |
| 2_E050               | Force event (eSDHC_FEVT)                        | 32                 | W      | 0000_0000h  | 16.4.16/<br>1229 |
| 2_E0FC               | Host controller version (eSDHC_HOSTVER)         | 32                 | R      | 0000_1201h  | 16.4.17/<br>1231 |
| 2_E40C               | DMA control register (eSDHC_DCR)                | 32                 | R/W    | 0000_0000h  | 16.4.18/<br>1232 |

## 16.4.1 DMA system address (eSDHC\_DSADDR)

The DMA system address register contains the system memory address used for DMA transfers. Only access this register when no transactions are executing (after transactions have stopped). The host driver should wait until PRSSTAT[DLA] is cleared.

The host driver should initialize this register before starting every DMA transaction.

Address: 2\_E000h base + 0h offset = 2\_E000h



#### eSDHC\_DSADDR field descriptions

| Field   | Description                                                                                                                                                                                                                                                                         |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DS_ADDR | DMA system address , lower 32 bits . When the eSDHC stops a DMA transfer, this register points to the system address of the next contiguous data position. The upper four bits of the DMA system address are stored in ECMCR[ESDHC_UPRADR], see ECM control register (GUTS_ECMCR) . |  |
|         | NOTE: The DS_ADDR must be aligned to a four-byte boundary; the two least-significant bits must be cleared.                                                                                                                                                                          |  |

## 16.4.2 Block attributes (eSDHC\_BLKATTR)

The block attributes register configures the number of data blocks and the number of bytes in each block. Only access this register when no transactions are executing (after transactions have stopped). The host driver should wait until PRSSTAT[DLA] is cleared.

Address: 2\_E000h base + 4h offset = 2\_E004h



#### eSDHC\_BLKATTR field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                      |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0-15<br>BLKCNT | Block count for current transfer. This field is enabled when XFERTYP[BCEN] is set and is valid only for multiple block transfers. The host driver should set this field to a value between 1 and the maximum block count. The eSDHC decrements the block count after each block transfer and stops when the count reaches zero. Clearing this field results in no data blocks being transferred. |  |
|                | 0000 Stop count<br>0001 1 block                                                                                                                                                                                                                                                                                                                                                                  |  |
|                | 0002 2 blocks                                                                                                                                                                                                                                                                                                                                                                                    |  |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eSDHC\_BLKATTR field descriptions (continued)

| Field  | Description                                                                                                                                                                |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |                                                                                                                                                                            |  |  |
|        | FFFF 65,535 blocks                                                                                                                                                         |  |  |
| 16–18  | This field is reserved.                                                                                                                                                    |  |  |
| -      |                                                                                                                                                                            |  |  |
| 19–31  | Transfer block size. Specifies the block size for block data transfers. Values can range from one byte up to                                                               |  |  |
| BLKSZE | the maximum buffer size.                                                                                                                                                   |  |  |
|        | The DMA always writes at least four bytes to memory. Thus, software should allocate a buffer space rounded up to a 4-byte alighted size in order to avoid data corruption. |  |  |
|        | 0000 No data transfer                                                                                                                                                      |  |  |
|        | 0001 1 byte                                                                                                                                                                |  |  |
|        | 0002 2 bytes                                                                                                                                                               |  |  |
|        | 0003 3 bytes                                                                                                                                                               |  |  |
|        | 0004 4 bytes                                                                                                                                                               |  |  |
|        |                                                                                                                                                                            |  |  |
|        | 01FF 511 bytes                                                                                                                                                             |  |  |
|        | 0200 512 bytes                                                                                                                                                             |  |  |
|        |                                                                                                                                                                            |  |  |
|        | <br>0800 2048 bytes                                                                                                                                                        |  |  |
|        | 1000 4096 bytes                                                                                                                                                            |  |  |

# 16.4.3 Command argument (eSDHC\_CMDARG)

The command argument register contains the SD/MMC command argument.

Address: 2\_E000h base + 8h offset = 2\_E008h



### eSDHC\_CMDARG field descriptions

| Field          | Description                                                                                                                                                                               |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0-31<br>CMDARG | Command argument. The SD/MMC command argument is specified as bits 39-8 of the command format in the SD or MMC Specification . If PRSSTAT[CIHB] is set, this register is write-protected. |  |

# 16.4.4 Command transfer type (eSDHC\_XFERTYP)

The transfer type register controls the operation of data transfers. The host driver should set this register before issuing a command followed by a data transfer. To prevent data loss, the eSDHC prevents a write to the bits that are involved in the data transfer of this register while the data transfer is active.

The host driver should check PRSSTAT[CDIHB] and PRSSTAT[CIHB] before writing to this register.

- If PRSSTAT[CDIHB] is set, any attempt to send a command with data by writing to this register is ignored.
- If PRSSTAT[CIHB] is set, any write to this register is ignored.

| Multi/Single Block Select<br>XFERTYP[MSBSEL] | Block Count Enable<br>XFERTYP[BCEN] | Block Count BLKATTR[BLKCNT] | Function          |
|----------------------------------------------|-------------------------------------|-----------------------------|-------------------|
| 0                                            | X                                   | Х                           | Single Transfer   |
| 1                                            | 0                                   | Х                           | Infinite Transfer |
| 1                                            | 1                                   | Positive Number             | Multiple Transfer |
| 1                                            | 1                                   | Zero                        | No Data Transfer  |

Table 16-6. Determination of transfer type

The table below shows how the response type can be determined by the command index check enable, command CRC check enable, and response type bits.

Table 16-7. Relation between parameters and name of response type

|    | Response Type<br>XFERTYP[RSPTYP] | Index Check Enable XFERTYP[CICEN] | CRC Check Enable<br>XFERTYP[CCCEN] | Response type |
|----|----------------------------------|-----------------------------------|------------------------------------|---------------|
| 00 |                                  | 0                                 | 0                                  | No Response   |
| 01 |                                  | 0                                 | 1                                  | R2            |
| 10 |                                  | 0                                 | 0                                  | R3, R4        |
| 10 |                                  | 1                                 | 1                                  | R1, R5, R6    |
| 11 |                                  | 1                                 | 1                                  | R1b, R5b      |

#### NOTE

The CRC field for R3 and R4 is expected to be all 1s. The CRC check should be disabled for these response types.

Address: 2\_E000h base + Ch offset = 2\_E00Ch



## eSDHC\_XFERTYP field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0–1<br>-      | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 2–7<br>CMDINX | Command index. These bits should be set to the command number (CMD0-63, ACMD0-63) that is specified in bits 45-40 of the command format in the <i>SD Memory Card Physical Layer Specification</i> .                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 8–9<br>CMDTYP | <ul> <li>Command type. There is one type of special command-abort. Clear this bit field for all other commands.</li> <li>Abort command. If this command is set when executing a read transfer, the eSDHC stops reads to the buffer. If this command is set when executing a write transfer, the eSDHC stops driving the SDHC_DAT line. After issuing the abort command, the host driver should issue a software reset. (Abort transaction)</li> <li>Normal-other commands</li> <li>Reserved</li> <li>Reserved</li> </ul> |  |  |  |
| 10<br>DPSEL   | <ul> <li>11 Abort-CMD12, CMD52 for writing I/O abort in CCCR</li> <li>Data present select. Set to indicate that data is present and should be transferred using the SDHC_DAT line. It is cleared for the following: <ul> <li>Commands using only the SDHC_CMD line (for example, CMD52)</li> <li>Commands with no data transfer but using busy signal on the SDHC_DAT[0] line (R1b or R5b, for example, CMD38)</li> </ul> </li> <li>No data present</li> <li>Data present</li> </ul>                                     |  |  |  |
| 11<br>CICEN   | Command index check enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |

# eSDHC\_XFERTYP field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                 | 0 Disable. The index field is not checked.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                 | 1 Enable. The eSDHC checks the index field in the response to see if it has the same value as the command index. If it is not, it is reported as a command index error.                                                                                                                                                                                                                                                                                                                      |  |  |
| 12<br>CCCEN     | Command CRC check enable. The number of bits checked by the CRC field value changes according to the length of the response. (See RSPTYP[1:0] and Table 16-6.)                                                                                                                                                                                                                                                                                                                               |  |  |
|                 | <ul> <li>Disable. The CRC field is not checked.</li> <li>Enable. The eSDHC checks the CRC field in the response if it contains the CRC field. If an error is detected, it is reported as a command CRC error.</li> </ul>                                                                                                                                                                                                                                                                     |  |  |
| 13<br>-         | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 14–15<br>RSPTYP | Response type select.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                 | 00 No response<br>01 Response length 136                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|                 | 10 Response length 48                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                 | 11 Response length 48 check busy after response                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 16–25           | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 26<br>MSBSEL    | Multi/single block select. Enables multiple block SDHC_DAT line data transfers. For any other commands, this bit should be cleared. If this bit is cleared, it is not necessary to set the block count register. (See Table 16-7.)  0 Single block                                                                                                                                                                                                                                           |  |  |
|                 | 1 Multiple blocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 27<br>DTDSEL    | Data transfer direction select. Defines the direction of SDHC_DAT line data transfers. The bit is set by the host driver to transfer data from the SD card to the eSDHC and it is cleared for all other commands.                                                                                                                                                                                                                                                                            |  |  |
|                 | 0 Write (host to card)                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                 | 1 Read (card to host)                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 28<br>-         | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 29<br>AC12EN    | Auto CMD12 enable. Multiple block transfers for memory require CMD12 to stop the transaction. If this bit is set, the eSDHC issues CMD12 automatically when the last block transfer is completed. The host driver should not set this bit to issue commands that do not require CMD12 to stop a multiple block data transfer. In particular, secure commands defined in the Part 3 File Security specification do not require CMD12. In a single block transfer, the eSDHC ignores this bit. |  |  |
|                 | <ul><li>0 Disable</li><li>1 Enable</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 30<br>BCEN      | Block count enable. Enables the block attributes register, which is only relevant for multiple block transfers. When this bit is cleared, the block attributes register is disabled, which is useful in executing an infinite transfer.                                                                                                                                                                                                                                                      |  |  |
|                 | 0 Disable 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 31<br>DMAEN     | DMA enable. Enables DMA functionality as described in DMA CCB interface. If this bit is set, a DMA operation should begin when the host driver writes to the CMDINX field of the transfer type register.                                                                                                                                                                                                                                                                                     |  |  |

#### eSDHC\_XFERTYP field descriptions (continued)

| Field | Description |
|-------|-------------|
|       | 0 Disable   |
|       | 1 Enable    |

## 16.4.5 Command response n (eSDHC\_CMDRSPn)

The command response registers store the four parts of the response bits from the card.

The table below describes the mapping of command responses from the SD bus to the command response registers for each response type. In the table, R[] refers to a bit range within the response data as transmitted on the SD bus.

Meaning of response Response Response type Response register field R1,R1b (normal response) Card status R[39:8] CMDRSP0 R[39:8] CMDRSP3 R1b (Auto CMD12 response) Card status for Auto CMD12 R2 (CID, CSD register) R[127:8] {CMDRSP3[23:0], CMDRSP2, CID/CSD register [127:8] CMDRSP1, CMDRSP0} R3 (OCR register) OCR register for memory R[39:8] CMDRSP0 R4 (OCR register) R[39:8] CMDRSP0 OCR register for I/O etc. R6 (publish RCA) New published RCA[31:16] and card R[39:8] CMDRSP0 status[15:0]

Table 16-9. Response bit definition for each response type

## This table shows the following:

- Most responses with a length of 48 (R[47:0]) have 32 bits of the response data (R[39:8]) stored in the CMDRSP0 register.
- Responses of type R1b (Auto CMD12 responses) have response data bits R[39:8] stored in the CMDRSP3 register.
- Responses with length 136 (R[135:0]) have 120 bits of the response data (R[127:8]) stored in the CMDRSP0, 1, 2, and 3 registers.

To be able to read the response status efficiently, the eSDHC only stores part of the response data in the command response registers. This enables the host driver to efficiently read 32 bits of response data in one read cycle on a 32-bit bus system. Parts of the response, the index field, and the CRC are checked by the eSDHC (as specified by XFERTYP[CICEN, CCCEN]) and generate an error interrupt if any error is detected. The bit range for the CRC check depends on the response length. If the response length is 48, the eSDHC checks R[47:1], and if the response length is 136, the eSDHC checks R[119:1].

Since the eSDHC may have a multiple block data transfer executing concurrently with a CMD\_wo\_DAT (Command without data) command, the eSDHC stores the Auto CMD12 response in the CMDRSP3 register and the CMD\_wo\_DAT response is stored in CMDRSP0. This allows the eSDHC to avoid overwriting the Auto CMD12 response with the CMD\_wo\_DAT and vice versa. When the eSDHC modifies part of the command response registers it preserves the unmodified bits.



### eSDHC\_CMDRSPn field descriptions

| Field | Description                                                                                                                              |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|--|
|       | Command response. See Command Response 0-3 for the mapping of command responses from the SD bus to this register for each response type. |  |

# 16.4.6 Data buffer access port (eSDHC\_DATPORT)

The buffer data port register is a 32-bit data port register used to access the internal buffer.

#### NOTE

When the internal DMA is not enabled and a write transaction is in operation, DATPORT must not be read. DATPORT also must not be used to read (or write) data by the CPU or external DMA if the data will be written (or read) by the eSDHC internal DMA.

Address: 2\_E000h base + 20h offset = 2\_E020h



#### eSDHC DATPORT field descriptions

| Field | Description                                                                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Data content. The buffer data port register is for 32-bit data access by the CPU . When the internal DMA is enabled, any write to this register is ignored, and a read from this register always yields 0. |

## 16.4.7 Present state (eSDHC\_PRSSTAT)

The present state register indicates the status of the eSDHC to the host driver.

#### **NOTE**

The host driver can issue CMD0, CMD12, CMD13 (for memory) when the SDHC\_DAT lines are busy during a data transfer. These commands can be issued when PRSSTAT[CIHB] is cleared. Other commands should be issued when PRSSTAT[CDIHB] is cleared. Possible changes to the SD physical specification may add other commands to this list in the future.







eSDHC\_PRSSTAT field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7<br>DLSL | SDHC_DAT[7:0] line signal level. These bits are used to check the SDHC_DAT line level to recover from errors, and for debugging. This is especially useful in detecting the busy signal level from SDHC_DAT[0]. The reset value is affected by the external pull resistors. By default, read value of this bit field after reset is 0b11110111, when SDHC_DAT[3] is pull-down and other lines are pull-up. |
|             | The meaning of PRSSTAT bits is as follows:                                                                                                                                                                                                                                                                                                                                                                 |
|             | PRSSTAT SDHC_DATn                                                                                                                                                                                                                                                                                                                                                                                          |
|             | 0 7                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 1 6                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 2 5                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 3 4                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 4 3                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 5 2                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 6 1                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 7 0                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8<br>CLSL   | SDHC_CMD line signal level. This status is used to check the SDHC_CMD line level to recover from errors, and for debugging. The reset value is affected by the external pull resistor, by default, read value of this bit after reset is 1, when the command line is pull-up.                                                                                                                              |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## eSDHC\_PRSSTAT field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9–11        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 12<br>WPSPL | Write protect switch pin level. The write protect switch is supported for memory cards. This bit reflects the inverse of the SDHC_WP pin of the card socket. A software reset does not affect this bit. The reset value is affected by the external write protect switch. If the SDHC_WP pin is not used (PMUXCR[SDHC_WP] = 0, Alternate function signal multiplex control (GUTS_PMUXCR)), so that the reset value of this bit is 1 and write is enabled.  0 Write protected (SDHC_WP = 1) 1 Write enabled (SDHC_WP = 0)                                                                            |
| 13<br>CDPL  | Card detect pin level. This bit reflects the inverse value of the SDHC_CD_B pin for the card socket. Debouncing is not performed on this bit. This bit may be valid, but it is not guaranteed because of a propagation delay. Use of this bit is limited to testing since it must be debounced by software. A software reset does not affect this bit. Write to the force event register does not affect this bit. The reset value is affected by the external card detection pin. If this bit is not used, it should be tied to 0.  O No card present (SDHC_CD_B = 1) Card present (SDHC_CD_B = 0) |
| 14          | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15<br>CINS  | Card inserted. Indicates if a card has been inserted. The eSDHC debounces this signal so that the host driver does not need to wait for it to stabilize. Changing from 0 to 1 generates a card-insertion interrupt in the interrupt status register and changing from 1 to 0 generates a card removal interrupt in the interrupt status register. A write to the force event register does not affect this bit.  The software reset for all in the system control register does not affect this bit. A software reset does not                                                                      |
|             | affect this bit.  0 Power-on-reset or no card  1 Card inserted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 16–19<br>-  | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20<br>BREN  | Buffer read enable. This status is used for non-DMA read transfers. The eSDHC may implement multiple buffers to transfer data efficiently. This read-only flag indicates that a burst-length of valid data exists in the host-side buffer.                                                                                                                                                                                                                                                                                                                                                          |
|             | When the buffer is read, this bit is cleared. When a burst length of data is ready in the buffer, this bit is set and a buffer read ready interrupt is generated (if the interrupt is enabled).                                                                                                                                                                                                                                                                                                                                                                                                     |
|             | 0 Buffer read disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21<br>BWEN  | 1 Buffer read enable  Buffer write enable. This status is used for non-DMA write transfers. The eSDHC can implement multiple buffers to transfer data efficiently. This read-only flag indicates if space is available for a burst length of write data.                                                                                                                                                                                                                                                                                                                                            |
|             | When the buffer is written, this bit is cleared. When a burst length of data is written to the buffer, this bit is set and a buffer write ready interrupt is generated (if the interrupt is enabled).                                                                                                                                                                                                                                                                                                                                                                                               |
|             | <ul><li>0 Buffer write disable</li><li>1 Buffer write enable</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22          | Read transfer active. This status is used for detecting completion of a read transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RTA         | This bit is set for either of the following conditions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

# eSDHC\_PRSSTAT field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <ul> <li>After the end bit of the read command</li> <li>When writing a 1 to PROCTL[CREQ] to restart a read transfer</li> </ul>                                                                                                                                                                                                                |
|              | This bit is cleared for either of the following conditions:                                                                                                                                                                                                                                                                                   |
|              | <ul> <li>When the last data block as specified by block length is transferred to the system</li> <li>When all valid data blocks have been transferred to the system and no current block transfers are being sent as a result of PROCTL[SABGREQ] being set. A transfer complete interrupt is generated when this bit changes to 0.</li> </ul> |
|              | 0 No valid data                                                                                                                                                                                                                                                                                                                               |
|              | 1 Transferring data                                                                                                                                                                                                                                                                                                                           |
| 23<br>WTA    | Write transfer active. This status indicates a write transfer is active. If this bit is 0, it means no valid write data exists in eSDHC.                                                                                                                                                                                                      |
|              | This bit is set in either of the following cases:                                                                                                                                                                                                                                                                                             |
|              | <ul> <li>After the end bit of the write command.</li> <li>When writing a 1 to PROCTL[CREQ] to restart a write transfer.</li> </ul>                                                                                                                                                                                                            |
|              | This bit is cleared in either of the following cases:                                                                                                                                                                                                                                                                                         |
|              | After getting the CRC status of the last data block, as specified by the transfer count (single and multiple)                                                                                                                                                                                                                                 |
|              | <ul> <li>After getting the CRC status of any block where data transmission is about to be stopped by a stop-<br/>at-block-gap request.</li> </ul>                                                                                                                                                                                             |
|              | During a write transaction, a IRQSTAT[BGE] interrupt is generated when this bit is changed to 0, as result of PROCTL[SABGREQ] being set. This status is useful for the host driver in determining when to issue commands during write busy.                                                                                                   |
|              | 0 No valid data                                                                                                                                                                                                                                                                                                                               |
|              | 1 Transferring data                                                                                                                                                                                                                                                                                                                           |
| 24<br>SDOFF  | SD clock gated off internally. Indicates the SD clock is internally gated off because of a buffer overrun, buffer underrun, or a read pause without read-wait assertion. This bit is for the host driver to debug data transaction on SD bus.                                                                                                 |
|              | This status bit resets to 0, but reflects the value of the automatic clock gating and may transition to 1 if the eSDHC is idle.                                                                                                                                                                                                               |
| 25<br>PEROFF | The internal bus clock gated off internally. This status bit indicates the internal bus clock is internally gated off. This bit is for the host driver to debug a transaction on SD bus.                                                                                                                                                      |
|              | This status bit resets to 0, but reflects the value of the automatic clock gating and may transition to 1 if the eSDHC is idle.                                                                                                                                                                                                               |
| 26<br>HCKOFF | Master clock gated off internally. This status bit indicates master clock is internally gated off. This bit is for the host driver to debug a data transfer.                                                                                                                                                                                  |
|              | This status bit resets to 0, but reflects the value of the automatic clock gating and may transition to 1 if the eSDHC is idle.                                                                                                                                                                                                               |
| 27<br>IPGOFF | Controller clock gated off internally. Indicates that the controller clock is internally gated off. This bit is for the host driver to debug.                                                                                                                                                                                                 |
|              | This status bit resets to 0, but reflects the value of the automatic clock gating and may transition to 1 if the eSDHC is idle.                                                                                                                                                                                                               |
|              |                                                                                                                                                                                                                                                                                                                                               |

# eSDHC\_PRSSTAT field descriptions (continued)

| 1 to 0 between data blocks generates a block gap event interrupt.  This bit is set in either of the following cases:  • After the end bit of the read command  • When writing a 1 to PROCTL[CREQ] to restart a read transfer  This bit is cleared in either of the following cases:  • When the end bit of the last data block is sent from the SD bus to the eSDHC  • When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the readwait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  • After the end bit of the write command  • When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  • When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Field | Description                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 to 0 between data blocks generates a block gap event interrupt.  This bit is set in either of the following cases:  • After the end bit of the read command • When writing a 1 to PROCTL(CREQ) to restart a read transfer  This bit is cleared in either of the following cases:  • When the end bit of the last data block is sent from the SD bus to the eSDHC • When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the read-wait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspence resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  • After the end bit of the write command  • When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  • When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  • When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  O SDHC_DAT line active  1 SDHC_DAT line active  1 SDHC_DAT line active  1 SDHC_DAT line active  1 Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC_DAT line  1 Cannot issue command which uses the SDHC_DAT line  1 Cannot issue command which uses the SDHC_DAT line  1 Cannot issue command which uses the SDHC_DAT line  1 Cannot issue command wing the SDHC_CMD line is not in use and the eSDHC can issue at SD/MMC command. Cerd when the c |       | Data line active. Indicates whether one of the SDHC_DAT line on SD bus is in use.                                                                                                                                        |
| After the end bit of the read command When writing a 1 to PROCTL[CREQ] to restart a read transfer  This bit is cleared in either of the following cases:  When the end bit of the last data block is sent from the SD bus to the eSDHC When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the read-wait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  After the end bit of the write command When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  SDHC_DAT line inactive  SDHC_DAT line inactive  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) line  Command inhibit (SDHC_DAT). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written.   | DLA   | For read transactions, this bit indicates if a read transfer is executing on the SD bus. Clearing this bit from 1 to 0 between data blocks generates a block gap event interrupt.                                        |
| When writing a 1 to PROCTL[CREQ] to restart a read transfer  This bit is cleared in either of the following cases:  When the end bit of the last data block is sent from the SD bus to the eSDHC  When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the read-wait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  After the end bit of the write command  When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  SDHC_DAT line inactive  SDHC_DAT line inactive  SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC baT line  Cannot issue command which uses the SDHC_DAT line  Can issue a SD/MMC command using the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue at some and the estimation of the source of a command complete interrupt.  When the SD card eleases write-busy prior to waiting only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.                                            |       | This bit is set in either of the following cases:                                                                                                                                                                        |
| When the end bit of the last data block is sent from the SD bus to the eSDHC When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the readwait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  After the end bit of the write command When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  SDHC_DAT line inactive  SDHC_DAT line inactive  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command which uses the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if t  |       |                                                                                                                                                                                                                          |
| When beginning a read wait transfer initiated by a stop at block gap request  The eSDHC waits at the next block gap by driving read wait at the start of the interrupt cycle. If the readwait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  • After the end bit of the write command • When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  • When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  • When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  0 SDHC_DAT line inactive  1 SDHC_DAT line inactive  1 SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  0 Can issue command which uses the SDHC_DAT line  1 Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. If the CDIHB bit is set, command conflict error  |       | This bit is cleared in either of the following cases:                                                                                                                                                                    |
| wait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend resume function.  For write transactions, this bit indicates that a write transfer is executing on the SD bus. Clearing this bit from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  • After the end bit of the write command • When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  • When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  • When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  0 SDHC_DAT line inactive  1 SDHC_DAT line inactive  1 SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT line  1 Cannot issue command which uses the SDHC_DAT line  1 Cannot issue command which uses the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command comflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit iremains set and IRQSTAT[CC]      |       |                                                                                                                                                                                                                          |
| from 1 to 0 generates a transfer complete interrupt.  This bit is set in any of the following cases:  • After the end bit of the write command • When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  • When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  • When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  0 SDHC_DAT line inactive  1 SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  0 Can issue command which uses the SDHC_DAT line 1 Cannot issue command which uses the SDHC_DAT line 2 Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_DAT line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command comflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                          |       | wait signal is already driven (data buffer cannot receive data), the eSDHC can wait for current block gap by continuing to drive the read-wait signal. It is necessary to support read wait in order to use the suspend/ |
| After the end bit of the write command When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  SDHC_DAT line inactive SDHC_DAT line active SDHC_DAT line active  COmmand inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  Can issue command which uses the SDHC_DAT line Cannot issue command which uses the SDHC_DAT line Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                              |       |                                                                                                                                                                                                                          |
| When writing a 1 to PROCTL[CREQ] to continue a write transfer  This bit is cleared in any of the following cases:  When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  SDHC_DAT line inactive  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  Can issue command which uses the SDHC_DAT line  Cannot issue command which uses the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | This bit is set in any of the following cases:                                                                                                                                                                           |
| When the SD card releases write-busy of the last data block, the eSDHC also detects if output is no busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.      When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request      SDHC_DAT line inactive      SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  Can issue command which uses the SDHC_DAT line  Cannot issue command which uses the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                                                                                                                                                                                                                          |
| busy. If the SD card does not drive the busy signal after CRC status is received, the eSDHC should consider the card drive not busy.  • When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block gap request  0 SDHC_DAT line inactive 1 SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set. If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  0 Can issue command which uses the SDHC_DAT line 1 Cannot issue command which uses the SDHC_DAT line 2 Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       | This bit is cleared in any of the following cases:                                                                                                                                                                       |
| 1 SDHC_DAT line active  Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set . If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  Can issue command which uses the SDHC_DAT line  Cannot issue command which uses the SDHC_DAT line  Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       | When the SD card releases write-busy prior to waiting for write transfer as a result of a stop at block                                                                                                                  |
| Command inhibit (SDHC_DAT). This bit is set if the SDHC_DAT line is active, the read transfer active is set . If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  0 Can issue command which uses the SDHC_DAT line 1 Cannot issue command which uses the SDHC_DAT line Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       | 0 SDHC_DAT line inactive                                                                                                                                                                                                 |
| set . If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0 generates a transfer complete interrupt.  O Can issue command which uses the SDHC_DAT line 1 Cannot issue command which uses the SDHC_DAT line Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | 1 SDHC_DAT line active                                                                                                                                                                                                   |
| 1 Cannot issue command which uses the SDHC_DAT line  31 Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       | set . If this bit is cleared, it indicates the eSDHC can issue the next SD/MMC command. Commands with busy signal belong to command inhibit (SDHC_DAT) (e.g. R1b and R5b type). Clearing from 1 to 0                     |
| Command inhibit (SDHC_CMD). This bit is cleared, if the SDHC_CMD line is not in use and the eSDHC can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | 0 Can issue command which uses the SDHC_DAT line                                                                                                                                                                         |
| CIHB can issue a SD/MMC command using the SDHC_CMD line.  This bit is set immediately after the XFERTYP register is written. This bit is cleared when the command response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | 1 Cannot issue command which uses the SDHC_DAT line                                                                                                                                                                      |
| response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be issued if this bit is cleared. Clearing from 1 to 0 generates a command complete interrupt.  If the eSDHC cannot issue the command because of a command conflict error (see the command CRC error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                                                                                                                                                                                                                          |
| error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | response is received. Even if the CDIHB bit is set, commands using only the SDHC_CMD line can be                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | error) or because of a command not issued by Auto CMD12 error, this bit remains set and IRQSTAT[CC]                                                                                                                      |
| 0 Can issue command using only SDHC_CMD line 1 Cannot issue command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |                                                                                                                                                                                                                          |

## 16.4.8 Protocol control (eSDHC\_PROCTL)

To restart the transfer after a stop at the block gap, the continue request should be used to restart the transfer.

Any time PROCTL[SABGREQ] stops the data transfer, the host driver should wait for IRQSTAT[TC] before attempting to restart the transfer. When restarting the data transfer by continue request, the host driver should clear PROCTL[SABGREQ] before or simultaneously.



eSDHC\_PROCTL field descriptions

| Field       | Description                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4         | This field is reserved.                                                                                                                                                                  |
| -           |                                                                                                                                                                                          |
| 5<br>WECRM  | Wake-up event enable on SD card removal. This bit enables wakeup event via card removal assertion in the IRQSTAT register. FN_WUS (wake-up support) in CIS does not affect this bit.     |
|             | 0 Disable                                                                                                                                                                                |
|             | 1 Enable                                                                                                                                                                                 |
| 6<br>WECINS | Wake-up event enable on SD card insertion. This bit enables wakeup event via card insertion assertion in the IRQSTAT register. FN_WUS (wake-up support) in CIS does not affect this bit. |

## eSDHC\_PROCTL field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | NOTE: When this bit is set, the card insertion status and the eSDHC interrupt can be asserted without SD_CLK toggling. When the wakeup feature is not enabled, the SD_CLK must be active in order to assert the card insertion status and the eSDHC interrupt.                                                                                                                                                                                |
|               | 0 Disable<br>1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7–12<br>-     | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13            | Read wait control. Not supported on this device.                                                                                                                                                                                                                                                                                                                                                                                              |
| RWCTL         | If the card supports read wait, set this bit to enable the read wait protocol to stop read data using the SDHC_DAT[2] line. Otherwise, the eSDHC has to stop the SD clock to hold read data, which restricts command generation.                                                                                                                                                                                                              |
|               | If the card does not support read wait, this bit should never be set otherwise an SDHC_DAT line conflict may occur. If this bit is cleared, a stop-at-block-gap-during-read operation is also supported, but the eSDHC stops the SD clock to pause the reading operation.                                                                                                                                                                     |
|               | 0 Disable read-wait control, and stop SD clock at block gap when the SABGREQ bit is set                                                                                                                                                                                                                                                                                                                                                       |
|               | 1 Enable read-wait control, and assert read wait without stopping the SD clock at block gap when PROCTL[SABGREQ] is set                                                                                                                                                                                                                                                                                                                       |
| 14<br>CREQ    | Continue request. Restarts a transaction which was stopped using the stop-at-block-gap request. To cancel the request, clear SABGREQ and set this bit to restart the transfer.                                                                                                                                                                                                                                                                |
|               | The eSDHC automatically clears this bit in either of the following cases:                                                                                                                                                                                                                                                                                                                                                                     |
|               | <ul> <li>For a read transaction, the PRSSTAT[DLA] bit changes from 0 to 1 as a read transaction restarts.</li> <li>For a write transaction, the PRSSTAT[WTA] bit changes from 0 to 1 as the write transaction restarts.</li> </ul>                                                                                                                                                                                                            |
|               | Therefore, it is not necessary for the host driver to clear. If SABGREQ and this bit are set, the continue request is ignored.                                                                                                                                                                                                                                                                                                                |
|               | 0 No effect<br>1 Restart                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15<br>SABGREQ | Stop at block gap request. Stops executing a transaction at the next block gap for both DMA and non-DMA transfers. Until the TC bit is set, indicating a transfer completion, the host driver should leave this bit set. Clearing SABGREQ and CREQ does not cause the transaction to restart.                                                                                                                                                 |
|               | The eSDHC stops the SD bus clock to pause the read operation during the block gap.                                                                                                                                                                                                                                                                                                                                                            |
|               | For write transfers in which the host driver writes data to the data port register, the host driver should set this bit after all block data is written. If this bit is set, the host driver should not write data to the DATPORT register after a block is sent. When this bit is set, the host driver should not clear this bit before IRQSTAT[TC] is set. Otherwise, the eSDHC behavior is undefined. Confirm that IRQSTAT[TC] is enabled. |
|               | This bit affects PRSSTAT[RTA, WTA, DLA, CIHB].                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 0 Transfer                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 1 Stop                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 16–23<br>-    | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 24<br>CDSS    | Card detect signal selection. Selects the source for card detection.                                                                                                                                                                                                                                                                                                                                                                          |
| CDSS          | 0 Card detection level is selected (for normal purpose)                                                                                                                                                                                                                                                                                                                                                                                       |
|               | 1 Card detection test level is selected (for test purpose)                                                                                                                                                                                                                                                                                                                                                                                    |

# eSDHC\_PROCTL field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                                                     |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>CDTL     | Card detect test level. Determines card insertion status when CDSS is set.                                                                                                                                                                                                                                      |
|                | 0 No card in the slot                                                                                                                                                                                                                                                                                           |
|                | 1 Card is inserted                                                                                                                                                                                                                                                                                              |
| 26–27<br>EMODE | Endian mode. eSDHC supports only address-invariant mode in data transfer.                                                                                                                                                                                                                                       |
|                | 00 Big endian mode                                                                                                                                                                                                                                                                                              |
|                | 01 Half-word big endian mode                                                                                                                                                                                                                                                                                    |
|                | 10 Little-endian mode                                                                                                                                                                                                                                                                                           |
|                | 11 Reserved                                                                                                                                                                                                                                                                                                     |
| 28<br>D3CD     | SDHC_DAT3 as card detection pin. If this bit is set, SDHC_DAT3 should be pulled down to act as a card detection pin. Be cautious when using this feature, because SDHC_DAT3 is chip-select for SPI mode, and a pull-down on this pin and CMD0 may set the card into SPI mode, which the eSDHC does not support. |
|                | 0 SDHC DAT3 does not monitor card insertion                                                                                                                                                                                                                                                                     |
|                | 1 SDHC_DAT3 is card detection pin                                                                                                                                                                                                                                                                               |
| 29–30<br>DTW   | Data transfer width. Selects the data width of the SD bus. The host driver should set it to match the data width of the card.                                                                                                                                                                                   |
|                | 00 1-bit mode                                                                                                                                                                                                                                                                                                   |
|                | 01 4-bit mode                                                                                                                                                                                                                                                                                                   |
|                | 10 8-bit mode                                                                                                                                                                                                                                                                                                   |
|                | 11 Reserved                                                                                                                                                                                                                                                                                                     |
| 31             | This field is reserved.                                                                                                                                                                                                                                                                                         |

# 16.4.9 System control (eSDHC\_SYSCTL)

Address: 2\_E000h base + 2Ch offset = 2\_E02Ch



## eSDHC\_SYSCTL field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–3<br>-   | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>INITA | Initialization active. When this bit is written '1', 80 SD clocks are sent to the card. After the 80 clocks are sent, this bit is self-cleared. This bit is very useful during the card power-up period when 74 SD clocks are needed and clock auto-gating feature is enabled.  Writing one to this bit when it is already set has no effect. Clearing this bit at any time does not affect it. |
|            | When PRSSTAT[CIHB] or PRSSTAT[CDIHB] is set, writing a one to this bit is ignored. That is, when the command line or data line is active, writing to this bit is not allowed.                                                                                                                                                                                                                   |
| 5<br>RSTD  | Software reset for SDHC_DAT line. The DMA and part of the data circuit are reset. The following registers and bits are cleared by this bit:  • DATPORT register  • Buffer is cleared and initialized; PRSSTAT register  • PRSSTAT[BREN, BWEN, RTA, WTA, DLA, CDIHB]  • PROCTL[CREQ, SABGREQ]  • IRQSTAT[BRR, BWR, DINT, BGE, TC]                                                                |
|            | 0 Work<br>1 Reset                                                                                                                                                                                                                                                                                                                                                                               |
| 6<br>RSTC  | Software reset for SDHC_CMD line. Only part of the command circuit is reset. The following bits are cleared by this bit:                                                                                                                                                                                                                                                                        |

# eSDHC\_SYSCTL field descriptions (continued)

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | PRSSTAT[CIHB]                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | • IRQSTAT[CC]                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | 0 Work                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | 1 Reset                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7<br>RSTA        | Software reset for all. This reset affects the entire host controller except for the card-detection circuit. Register bits of type ROC, RW, RW1C, and RWAC are cleared.                                                                                                                                                                                                                                                 |
|                  | During its initialization, the host driver should set this bit to reset the eSDHC. The eSDHC should clear this bit when capabilities registers are valid and the host driver can read them. Additional use of the this bit does not affect the value of the capabilities registers. After this bit is set, it is recommended the host driver reset the external card and re-initialize it.                              |
| l                | 0 Work                                                                                                                                                                                                                                                                                                                                                                                                                  |
| l                | 1 Reset                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8–11<br>-        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12–15<br>DTOCV   | Data timeout counter value. Determines the interval by which SDHC_DAT line timeouts are detected. See the data timeout error Interrupt status (eSDHC_IRQSTAT), for information on factors that dictate timeout generation. Timeout clock frequency is generated by dividing the base clock SDHC_CLK value by this value. When setting this register, prevent inadvertent timeout events by clearing IRQSTATEN[DTOESEN]. |
| l                | 0000 SDHC_CLK x 2 <sup>13</sup>                                                                                                                                                                                                                                                                                                                                                                                         |
| l                | 0001 SDHC_CLK x 2 <sup>14</sup>                                                                                                                                                                                                                                                                                                                                                                                         |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                         |
| l                | 1110 SDHC_CLK x 2 <sup>27</sup>                                                                                                                                                                                                                                                                                                                                                                                         |
|                  | 1111 Reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16–23<br>SDCLKFS | SDHC_CLK frequency select. This field, together with DVS, selects the frequency of SDHC_CLK pin. This bit holds the prescaler of the base clock frequency. Only the following settings are allowed:                                                                                                                                                                                                                     |
|                  | Multiple bits must not be set or the behavior of this prescaler is undefined.                                                                                                                                                                                                                                                                                                                                           |
|                  | According to the SD Physical Specification version 2.0, the maximum SD clock frequency is 52 MHz, and should never exceed this limit. The frequency of SDHC_CLK is set by the following formula:                                                                                                                                                                                                                        |
| l                | clock frequency = (base clock) ÷ [(SDCLKFS x 2) x (DVS +1)]                                                                                                                                                                                                                                                                                                                                                             |
|                  | For example, if the base clock frequency is 96 MHz, and the target frequency is 25 MHz, then choosing the prescaler value of 0x1 and divisor value of 0x1 yields 24 MHz, which is the nearest frequency less than or equal to the target. Similarly, to approach a clock value of 400 kHz, the prescaler value of 0x8 and divisor value of 0xE yields the exact clock value of 400 kHz.                                 |
| 1                | The reset value of this bit field is 0x80. So, if the input base clock is about 96 MHz, the default SD clock after reset is 375 kHz.                                                                                                                                                                                                                                                                                    |
|                  | NOTE: The base clock frequency equals the platform clock/2.                                                                                                                                                                                                                                                                                                                                                             |
|                  | 0x01 Base clock divided by 2                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 0x02 Base clock divided by 4                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 0x04 Base clock divided by 8                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 0x08 Base clock divided by 16                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | 0x10 Base clock divided by 32                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | 0x20 Base clock divided by 64                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | 0x40 Base clock divided by 128                                                                                                                                                                                                                                                                                                                                                                                          |

# eSDHC\_SYSCTL field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24–27<br>DVS  | Divisor. Provides a more exact divisor to generate the desired SD clock frequency. The settings are as follows:  0x0 Divide by 1 0x1 Divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 0xE Divide by 15 0xF Divide by 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 28<br>SDCLKEN | SD clock enable. To change the SDCLK frequency, this bit must be cleared. The host controller should stop SDCLK when clearing this bit, but should maintain the same clock frequency until SDCLK is stopped (stop at SDCLK = 0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | If PRSSTAT[CINS] is cleared, the host driver should also clear SDCLKEN to save power.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 0 SD clock is disabled 1 SD clock is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 29<br>PEREN   | Peripheral clock enable. If set, the peripheral clock is always active and no automatic gating is applied, thus SDHC_CLK is active only except auto gating-off during buffer danger. If cleared, the peripheral clock is automatically off when no transaction is on the SD bus. Clearing this bit does not stop SDHC_CLK immediately. The peripheral clock will be internally gated off, if none of the following factors are met:  • Command part is reset  • Data part is reset  • Soft reset  • Command is about to send  • Clock divisor is just updated  • Continue request is just set  • This bit is set  • Card insertion is detected  • Card external interrupt is detected  • Card external interrupt is detected  • 80 clocks for initialization phase is ongoing   0 The peripheral clock is internally gated off  1 The peripheral clock is not automatically gated off |
| 30<br>HCKEN   | Master clock enable. If set, master clock is always active and no automatic gating is applied. If cleared, master clock is automatically off when no data transfer is on SD bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | NOTE: Master clock is the clock to the DMA engine and to the system bus interface logic.  O Master clock is internally gated off  Master clock is not automatically gated off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31<br>IPGEN   | Controller clock enable. If this bit is set, the controller clock is always active and no automatic gating is applied. The controller clock is internally gated off, if neither the following factors is met:  • Command part is reset  • Data part is reset  • Soft reset  • Command is about to send  • Clock divisor is just updated  • Continue request is just set  • This bit is set  • Card insertion is detected  • Card removal is detected                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### eSDHC\_SYSCTL field descriptions (continued)

| Field | Description                                                                                                                                                                 |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Card external interrupt is detected                                                                                                                                         |
|       | The internal bus clock is not gated off                                                                                                                                     |
|       | NOTE: The controller clock is not auto-gated off if the peripheral clock is not gated off. So, clearing this bit only does not take effect if SYSCTL[PEREN] is not cleared. |
|       | 0 The controller clock is internally gated off                                                                                                                              |
|       | 1 The controller clock is not automatically gated off                                                                                                                       |

## 16.4.10 Interrupt status (eSDHC\_IRQSTAT)

An interrupt is generated when one of the status bits and its corresponding interrupt enable bit are set. For all bits (except BGE), writing one to a bit clears it, while writing zero keeps the bit unchanged. More than one status can be cleared with a single register write.

The table below shows that command timeout error has higher priority than command complete. If both bits are set, it can be assumed that the response was not received correctly.

Table 16-23. Relation between command timeout error and command complete status

| Command complete | Command timeout error | Meaning of the status                           |
|------------------|-----------------------|-------------------------------------------------|
| 0                | 0                     | -                                               |
| X                |                       | Response not received within 64 SDHC_CLK cycles |
| 1                | 0                     | Response received                               |

The table below shows that transfer complete has higher priority than the data timeout error. If both bits are set, the data transfer can be considered complete.

Table 16-24. Relation between data timeout error and transfer complete status

| Transfer complete | Data timeout error | Meaning of the status         |
|-------------------|--------------------|-------------------------------|
| 0                 | 0                  | -                             |
| 0                 | 1                  | Timeout occur during transfer |
| 1                 | Х                  | Data transfer complete        |

The relation between command CRC error and command timeout error is shown below.

Table 16-25. Relation between command CRC error and command timeout error

| Command CRC error | Command timeout error | Meaning of the status  |
|-------------------|-----------------------|------------------------|
| 0                 | 0                     | No error               |
| 0                 | 1                     | Response timeout error |
| 1                 | 0                     | Response CRC error     |
| 1                 | 1                     | SDHC_CMD line conflict |





## eSDHC\_IRQSTAT field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–2        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3<br>DMAE  | DMA error. Occurs when internal DMA transfer failed. This bit is set when some error occurs in the data transfer. The value in the DMA system address register is the next fetch address where the error occurs. Since any error corrupts the entire data block, the host driver should restart the transfer from the corrupted block boundary. The address of the block boundary can be calculated from the current DS_ADDR value or the remaining number of blocks and the block size.  O No Error              |
|            | 1 Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4–6        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7<br>AC12E | Auto CMD12 error. Occurs when one of the bits in AUTOC12ERR is set. This bit is also set when Auto CMD12 is not executed due to a previous command error.  O No Error  T Error                                                                                                                                                                                                                                                                                                                                    |
| 8 -        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9<br>DEBE  | Data end bit error. Occurs when detecting 0 at the end bit position of read data on the SDHC_DAT line or at the end bit position of the CRC.                                                                                                                                                                                                                                                                                                                                                                      |
|            | 0 No Error<br>1 Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10<br>DCE  | Data CRC error. Occurs when detecting CRC error when transferring read data on the SDHC_DAT line or when detecting the write CRC status having a value other than 0b010.                                                                                                                                                                                                                                                                                                                                          |
|            | 0 No Error<br>1 Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11<br>DTOE | Data timeout error. Occurs during one of following timeout conditions:  • Busy timeout for R1b and R5b types  • Busy timeout after write CRC status  • Read data timeout  0 No error                                                                                                                                                                                                                                                                                                                              |
| 10         | 1 Timeout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12<br>CIE  | Command index error. Occurs if a command index error occurs in the command response.  NOTE: Under rare conditions, CIE may be set for a command without data while a command with data is in progress. On detecting a command CRC error (IRQSTAT[CCE]) or command index error (IRQSTAT[CIE]), perform error recovery and re-issue the command without data. If Auto CMD12 is enabled for data transfer then Auto CMD12 won't be issued by hardware, so software needs to issue it after data transfer completion. |
|            | 1 Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>CEBE | Command end bit error. Occurs when the end bit of a command response is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|            | <ul><li>0 No error</li><li>1 End bit error generated</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | ו בווע טוג פווטו עפוופומנפע                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# eSDHC\_IRQSTAT field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 14<br>CCE  | <ul> <li>Command CRC error. A command CRC error is generated in two cases:</li> <li>If a response is returned and IRQSTAT[CTOE] is cleared (indicating no timeout), this bit is set when detecting a CRC error in the command response.</li> <li>The eSDHC detects a SDHC_CMD line conflict by monitoring the SDHC_CMD line when a command is issued. If the eSDHC drives the SDHC_CMD line to 1, but detects 0 on the SDHC_CMD line at the next SDHC_CLK edge, then the eSDHC aborts the command (stop driving SDHC_CMD line) and sets this bit. The CTOE bit is also set to distinguish the SDHC_CMD line conflict.</li> </ul> |  |
|            | NOTE: Under rare conditions, CCE may be set for a command without data while a command with data is in progress. On detecting a command CRC error (IRQSTAT[CCE]) or command index error (IRQSTAT[CIE]), perform error recovery and re-issue the command without data. If Auto CMD12 is enabled for data transfer then Auto CMD12 won't be issued by hardware, so software needs to issue it after data transfer completion.                                                                                                                                                                                                      |  |
|            | <ul><li>0 No error</li><li>1 CRC error generated</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 15<br>CTOE | Command timeout error. Occurs if no response is returned within 64 SDHC_CLK cycles from the end bit of the command. Also, if eSDHC detects a SDHC_CMD line conflict, this bit is set along with IRQSTAT[CCE] as shown in Table 16-35.                                                                                                                                                                                                                                                                                                                                                                                            |  |
|            | 0 No error 1 Time out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 16–23<br>- | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 24<br>CRM  | Card removal. This bit is set if PRSSTAT[CINS] changes from 1 to 0. When the host driver writes 1 to this bit to clear it, the status of PRSSTAT[CINS] should be confirmed. Because the card-detect state may be changed when the host driver clears this bit, an interrupt event may not be generated.                                                                                                                                                                                                                                                                                                                          |  |
|            | When this bit is cleared, it is set again if no card is inserted. To leave it cleared, clear IRQSTATEN[CRMSEN].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|            | <ul><li>0 Card state unstable or inserted</li><li>1 Card removed</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 25<br>CINS | Card insertion. This bit is set if PRSSTAT[CINS] changes from 0 to 1. When the host driver writes 1 to this bit to clear it, the status of PRSSTAT[CINS] should be confirmed. Because the card-detect state may be changed when the host driver clears this bit, an interrupt event may not be generated.                                                                                                                                                                                                                                                                                                                        |  |
|            | When this bit is cleared, it is set again if a card has been inserted. To leave it cleared, clear IRQSTATEN[CINSEN].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|            | <ul><li>0 Card state unstable or removed</li><li>1 Card inserted</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 26<br>BRR  | Buffer read ready. This bit is set if PRSSTAT[BREN] changes from 0 to 1.  0 Not ready to read buffer 1 Ready to read buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 27<br>BWR  | Buffer write ready. This bit is set if PRSSTAT[BWEN] changes from 0 to 1.  0 Not ready to write buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|            | 1 Ready to write buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 28<br>DINT | DMA interrupt. Occurs when the internal DMA finishes the data transfer successfully. If errors occur during data transfer, this bit is not set. Instead, the DMAE bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |

#### eSDHC\_IRQSTAT field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                 |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|           | 0 No DMA interrupt                                                                                                                                                                                                                                                                                          |  |  |
|           | 1 DMA interrupt is generated                                                                                                                                                                                                                                                                                |  |  |
| 29<br>BGE | Block gap event. If PROCTL[SABGREQ] is set, this bit is set when a read or write transaction is stopped at a block gap. If PROCTL[SABGREQ] is cleared, this bit is not set.                                                                                                                                 |  |  |
|           | During a read transaction, this bit is set at the falling edge of the SDHC_DAT line active status (when the transaction is stopped at SD bus timing). Read wait must be supported to use this function.                                                                                                     |  |  |
|           | During a write transaction, this bit is set at the falling edge of PRSSTAT[WTA] (after reading the CRC status at SD bus timing).                                                                                                                                                                            |  |  |
|           | 0 No block gap event                                                                                                                                                                                                                                                                                        |  |  |
|           | 1 Transaction stopped at block gap                                                                                                                                                                                                                                                                          |  |  |
| 30        | Transfer complete. This bit is set when a read or write transfer is completed.                                                                                                                                                                                                                              |  |  |
| TC        | For a read transaction, this bit is set at the falling edge of PRSSTAT[RTA]. There are two cases in which this interrupt is generated:                                                                                                                                                                      |  |  |
|           | <ul> <li>When a data transfer completes, as specified by the data length (after the last data has been read to the host system).</li> <li>When data has stopped at the block gap and completed the data transfer by setting PROCTL[SABGREQ] (after valid data has been read to the host system).</li> </ul> |  |  |
|           | For a write transaction, this bit is set at the falling edge of PRSSTAT[DLA]. There are two cases in which this interrupt is generated:                                                                                                                                                                     |  |  |
|           | <ul> <li>When the last data is written to the SD card, as specified by data length and the busy signal is released.</li> <li>When data transfers are stopped at the block gap by setting PROCTL[SABGREQ] and data</li> </ul>                                                                                |  |  |
|           | transfers have completed (after valid data is written to the SD card and the busy signal is released).                                                                                                                                                                                                      |  |  |
| 31<br>CC  | Command complete. This bit is set when the end bit of the command response is received (except Auto CMD12). See PRSSTAT[CIHB].                                                                                                                                                                              |  |  |
|           | 0 No command complete 1 Command complete                                                                                                                                                                                                                                                                    |  |  |

## 16.4.11 Interrupt status enable (eSDHC\_IRQSTATEN)

Setting the bits of IRQSTATEN enables the corresponding interrupt status bit to be set by the specified event. If any bit is cleared, the corresponding IRQSTAT bit is also cleared and is never set.

#### NOTE

The eSDHC may sample the card interrupt signal during the interrupt period and hold its value in the flip-flop. As a result of synchronization, there is a delay in the card interrupt (which is asserted from the card) to the time the host system is informed.

#### **NOTE**

To detect a SDHC\_CMD line conflict, the host driver must set both CTOESEN and CCESEN bits.

Address: 2\_E000h base + 34h offset = 2\_E034h



## eSDHC\_IRQSTATEN field descriptions

| Field        | Description                      |
|--------------|----------------------------------|
| 0–2          | This field is reserved.          |
| -            |                                  |
| 3<br>DMAESEN | DMA error status enable          |
|              | 0 Masked                         |
|              | 1 Enabled                        |
| 4–6          | This field is reserved.          |
| -            |                                  |
| 7            | Auto CMD12 error status enable   |
| AC12ESEN     | 0 Masked                         |
|              | 1 Enabled                        |
| 0            |                                  |
| 8 -          | This field is reserved.          |
| 9            | Data end bit error status enable |
| DEBESEN      |                                  |
|              | 0 Masked                         |
|              | 1 Enabled                        |

# eSDHC\_IRQSTATEN field descriptions (continued)

| Field         | Description                         |
|---------------|-------------------------------------|
| 10<br>DCESEN  | Data CRC error status enable        |
|               | 0 Masked<br>1 Enabled               |
| 11<br>DTOESEN | Data timeout error status enable    |
| J : 0_0       | 0 Masked<br>1 Enabled               |
| 12<br>CIESEN  | Command index error status enable   |
| O LOCATO      | 0 Masked<br>1 Enabled               |
| 13<br>CEBESEN | Command end bit error status enable |
| OLDLOLIN      | 0 Masked<br>1 Enabled               |
| 14<br>CCESEN  | Command CRC error status enable     |
| OOLOLIN       | 0 Masked<br>1 Enabled               |
| 15<br>CTOESEN | Command timeout error status enable |
| OTOLOLIN      | 0 Masked<br>1 Enabled               |
| 16–23         | This field is reserved.             |
| 24<br>CRMSEN  | Card removal status enable          |
| OTHVICETY     | 0 Masked<br>1 Enabled               |
| 25<br>CINSEN  | Card insertion status enable        |
| Onvociv       | 0 Masked<br>1 Enabled               |
| 26<br>BRRSEN  | Buffer read ready status enable     |
| Britioen      | 0 Masked<br>1 Enabled               |
| 27<br>BWRSEN  | Buffer write ready status enable    |
| DWHOLIN       | 0 Masked<br>1 Enabled               |
| 28<br>DINTSEN | DMA interrupt status enable         |
| DINIGEN       | 0 Masked<br>1 Enabled               |
| 29            | Block gap event status enable       |
| BGESEN        |                                     |

#### eSDHC\_IRQSTATEN field descriptions (continued)

| Field       | Description                     |
|-------------|---------------------------------|
|             | 0 Masked                        |
|             | 1 Enabled                       |
| 30<br>TCSEN | Transfer complete status enable |
|             | 0 Masked                        |
|             | 1 Enabled                       |
| 31<br>CCSEN | Command complete status enable  |
|             | 0 Masked                        |
|             | 1 Enabled                       |

# 16.4.12 Interrupt signal enable (eSDHC\_IRQSIGEN)

IRQSIGEN selects which interrupt status is indicated to the host system as the interrupt. These status bits all share the same interrupt line. Setting any of these bits enables an interrupt generation. The corresponding status register bit generates an interrupt when the corresponding interrupt signal enable bit is set.





# eSDHC\_IRQSIGEN field descriptions

| Field         | Description                                                |
|---------------|------------------------------------------------------------|
| 0–2           | This field is reserved.                                    |
| 3<br>DMAEIEN  | DMA error interrupt enable  0 Masked  1 Enabled            |
| 4–6           | This field is reserved.                                    |
| 7<br>AC12EIEN | Auto CMD12 error interrupt enable  0 Masked 1 Enabled      |
| 8 -           | This field is reserved.                                    |
| 9<br>DEBEIEN  | Data end bit error interrupt enable  0 Masked 1 Enabled    |
| 10<br>DCEIEN  | Data CRC error interrupt enable  0 Masked 1 Enabled        |
| 11<br>DTOEIEN | Data timeout error interrupt enable  0 Masked 1 Enabled    |
| 12<br>CIEIEN  | Command index error interrupt enable  0 Masked 1 Enabled   |
| 13<br>CEBEIEN | Command end bit error interrupt enable  0 Masked 1 Enabled |
| 14<br>CCEIEN  | Command CRC error interrupt enable  0 Masked 1 Enabled     |
| 15<br>CTOEIEN | Command timeout error interrupt enable  0 Masked 1 Enabled |
| 16–23<br>-    | This field is reserved.                                    |
| 24<br>CRMIEN  | Card removal interrupt enable  0 Masked 1 Enabled          |

#### eSDHC\_IRQSIGEN field descriptions (continued)

| Field         | Description                         |
|---------------|-------------------------------------|
| 25<br>CINSIEN | Card insertion interrupt enable     |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 26<br>BRRIEN  | Buffer read ready interrupt enable  |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 27<br>BWRIEN  | Buffer write ready interrupt enable |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 28<br>DINTIEN | DMA interrupt enable                |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 29<br>BGEIEN  | Block gap event interrupt enable    |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 30<br>TCIEN   | Transfer complete interrupt enable  |
|               | 0 Masked                            |
|               | 1 Enabled                           |
| 31<br>CCIEN   | Command complete interrupt enable   |
|               | 0 Masked                            |
|               | 1 Enabled                           |

# 16.4.13 Auto CMD12 status (eSDHC\_AUTOC12ERR)

When IRQSTAT[AC12E] is set, the host driver checks this register to identify what kind of error Auto CMD12 indicated. This register is valid only when IRQSTAT[AC12E] is set.

Table 16-29. Relationship between command CRC error and command timeout error for Auto CMD12

| Auto CMD12 CRC error | Auto CMD12 timeout error | Types of error         |
|----------------------|--------------------------|------------------------|
| 0                    | 0                        | No error               |
| 0                    | 1                        | Response timeout error |
| 1                    | 0                        | Response CRC error     |
| 1                    | 1                        | SDHC_CMD line conflict |

There are three scenarios when AUTOC12ERR can be changed:

- 1. When eSDHC is going to issue Auto CMD12
  - Set AC12NE if Auto CMD12 cannot be issued due to an error in the previous command.
  - Clear AC12NE if Auto CMD12 is issued.
- 2. At the end bit of an Auto CMD12 response
  - Check received responses by checking the error bits 1-4.
  - Set if error is detected.
  - Clear if error is not detected.
- 3. Before reading AUTOC12ERR[CNIBAC12E]
  - Set CNIBAC12E if there is a command that cannot be issued
  - Clear CNIBAC12E if there is no command to issue

The timing of generating the Auto CMD12 error and writing to the command register is asynchronous. The command may be blocked by any Auto CMD12 error causing CNIBAC12E to be set. Therefore, it is suggested to read this register only when IRQSTAT[AC12E] is set. An Auto CMD12 error interrupt is generated when one of the error bits 0-4 is set. The CNIBAC12E error bit does not generate an interrupt.







## eSDHC\_AUTOC12ERR field descriptions

| Field           | Description                                                                                                                                                                                   |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–23            | This field is reserved.                                                                                                                                                                       |
| 24<br>CNIBAC12E | Command not issued by Auto CMD12 error. This bit is set when CMD_wo_DAT is not executed due to an Auto CMD12 error (D04-D01).                                                                 |
|                 | 0 No error                                                                                                                                                                                    |
|                 | 1 Not Issued                                                                                                                                                                                  |
| 25–26<br>-      | This field is reserved.                                                                                                                                                                       |
| 27<br>AC12IE    | Auto CMD12 index error. Occurs if the command index error occurs in response to a command.                                                                                                    |
|                 | 0 No error                                                                                                                                                                                    |
|                 | 1 Error, the CMD index in response is not CMD12                                                                                                                                               |
| 28<br>AC12CE    | Auto CMD12 CRC error. Occurs when detecting a CRC error in the command response.                                                                                                              |
|                 | 0 No CRC error                                                                                                                                                                                |
|                 | 1 CRC error met in Auto CMD12 response                                                                                                                                                        |
| 29<br>AC12EBE   | Auto CMD12 end bit error. Occurs when detecting that the end bit of command response is 0 when it should be 1.                                                                                |
|                 | 0 No error                                                                                                                                                                                    |
|                 | 1 End bit error generated                                                                                                                                                                     |
| 30<br>AC12TOE   | Auto CMD12 timeout error. Occurs if no response is returned within 64 SDHC_CLK cycles from the end bit of the command. If this bit is set, the other error status bits (2-4) are meaningless. |
|                 | 0 No error                                                                                                                                                                                    |
|                 | 1 Time out                                                                                                                                                                                    |
| 31              | Auto CMD12 not executed. If a memory multiple block data transfer is not started due to command error,                                                                                        |
| AC12NE          | this bit is not set because it is not necessary to issue Auto CMD12. Setting this bit means eSDHC cannot                                                                                      |

### Chapter 16 Enhanced secure digital host controller (eSDHC)

# eSDHC\_AUTOC12ERR field descriptions (continued)

| Field | Description                                                                                                 |  |  |
|-------|-------------------------------------------------------------------------------------------------------------|--|--|
|       | issue Auto CMD12 to stop the memory multiple block data transfer due to some error. If this bit is set, the |  |  |
|       | other error status bits (1-4) are meaningless.                                                              |  |  |
|       | 0 Executed                                                                                                  |  |  |
|       | 1 Not executed                                                                                              |  |  |

# 16.4.14 Host controller capabilities (eSDHC\_HOSTCAPBLT)

The host controller capabilities provides the host driver with information specific to the eSDHC implementation. The value in this register does not change in a software reset, and any write to this register is ignored.







### eSDHC\_HOSTCAPBLT field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4<br>-   | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5<br>VS18  | Voltage support 1.8 V. This bit depends on the host system ability.  0 1.8 V not supported  1 1.8 V supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6<br>VS30  | Voltage support 3.0 V. This bit depends on the host system ability.  0 3.0 V not supported 1 3.0 V supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7<br>VS33  | Voltage support 3.3 V. This bit depends on the host system ability.  0 3.3 V not supported  1 3.3 V supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8 -        | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9<br>DMAS  | DMA support. Indicates if eSDHC is capable of using internal DMA to transfer data between system memory and the data buffer directly.  0 DMA not supported 1 DMA supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10<br>HSS  | High speed support. Indicates if the eSDHC supports high speed mode and the host system can supply the SD clock frequency from 25 to 50 MHz.  Under the speed supported supported the speed supported the spee |
| 11–12<br>- | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### **Enhanced Secure Digital Host Controller (eSDHC) Memory Map**

### eSDHC\_HOSTCAPBLT field descriptions (continued)

| Field        | Description                                                                                                                                                                    |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 13–15<br>MBL | Max block length. Indicates the maximum block size that the host driver can read and write to the buffer the eSDHC. The buffer should transfer block size without wait cycles. |  |
|              | 000 512 bytes                                                                                                                                                                  |  |
|              | 001 1024 bytes                                                                                                                                                                 |  |
|              | 010 2048 bytes                                                                                                                                                                 |  |
|              | 011 4096 bytes                                                                                                                                                                 |  |
| 16–31        | This field is reserved.                                                                                                                                                        |  |
| -            |                                                                                                                                                                                |  |

# 16.4.15 Watermark level (eSDHC\_WML)

Both write and read watermark levels are configurable. The value can be any number from 1-128 words.

Address: 2\_E000h base + 44h offset = 2\_E044h



#### eSDHC\_WML field descriptions

| Field           | Description                                                                                                                                                                                                                          |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–7             | This field is reserved.                                                                                                                                                                                                              |  |
| -               |                                                                                                                                                                                                                                      |  |
| 8–15<br>WR_WML  | Write watermark level. Number of 32-bit words of watermark level in DMA write operation. Also, the number of words of write burst length.                                                                                            |  |
|                 | NOTE: The minimum value is 0x02, which represents 2 words (8 bytes).                                                                                                                                                                 |  |
| 16–23<br>-      | This field is reserved.                                                                                                                                                                                                              |  |
| 24–31<br>RD_WML | Read watermark level. Number of 32-bit words of watermark level in DMA read operation. Also, the number of words of read burst length.                                                                                               |  |
|                 | NOTE: The minimum value for RD_WML is 0x02, which means 2 words (8 bytes), and the maximum value for RD_WML is 0x10, which means 16 words (64 bytes). Setting RD_WML to values outside this range results in non-predicted behavior. |  |

# 16.4.16 Force event (eSDHC\_FEVT)

The force event register is not a physically implemented register. Rather, it is an address to which the IRQSTAT register can be written if the corresponding bit of IRQSTATEN is set. Therefore, this register is a write-only register and writing zero has no effect . Writing 1 to this register sets the corresponding bit of IRQSTAT. Reading from this register always returns zeroes .

Forcing a card interrupt generates a short pulse on the SDHC\_DAT[1] line, and the driver may treat this interrupt as normal. The interrupt service routine may skip polling the card-interrupt source as the interrupt is self-cleared.



Address: 2\_E000h base + 50h offset = 2\_E050h

#### Enhanced Secure Digital Host Controller (eSDHC) Memory Map



### eSDHC\_FEVT field descriptions

| Field          | Description                                                      |
|----------------|------------------------------------------------------------------|
| 0–2<br>-       | This field is reserved.                                          |
| 3<br>FEVTDMAE  | Force event DMA error. Forces IRQSTAT[DMAE] to set.              |
| 4–6            | This field is reserved.                                          |
| 7<br>FEVTAC12E | Force event Auto CMD12 error. Forces IRQSTAT[AC12E] to set.      |
| 8 -            | This field is reserved.                                          |
| 9<br>FEVTDEBE  | Force event data end bit error. Forces IRQSTAT[DEBE] to set.     |
| 10<br>FEVTDCE  | Force event data CRC error. Forces IRQSTAT[DCE] to set.          |
| 11<br>FEVTDTOE | Force event data time out error. Forces IRQSTAT[DTOE] to set.    |
| 12<br>FEVTCIE  | Force event command index error. Forces IRQSTAT[CCE] to set.     |
| 13<br>FEVTCEBE | Force event command end bit error. Forces IRQSTAT[CEBE] to set.  |
| 14<br>FEVTCCE  | Force event command CRC error. Forces IRQSTAT[CCE] to set.       |
| 15<br>FEVTCTOE | Force event command time out error. Forces IRQSTAT[CTOE] to set. |
| 16–23<br>-     | This field is reserved.                                          |

### eSDHC\_FEVT field descriptions (continued)

| Field               | Description                                                                                |
|---------------------|--------------------------------------------------------------------------------------------|
| 24<br>FEVTCNIBAC12E | Force event command not executed by Auto CMD12 error. Forces AUTOC12ERR[CNIBAC12E] to set. |
| 25–26<br>-          | This field is reserved.                                                                    |
| 27<br>FEVTAC12IE    | Force event Auto CMD12 index error. Forces AUTOC12ERR[AC12IE] to set.                      |
| 28<br>FEVTAC12EBE   | Force event Auto CMD12 end bit error. Forces AUTOC12ERR[AC12EBE] to set.                   |
| 29<br>FEVTAC12CE    | Force event Auto CMD12 CRC error. Forces AUTOC12ERR[AC12CE] to set.                        |
| 30<br>FEVTAC12TOE   | Force event Auto CMD12 time out error. Forces AUTOC12ERR[AC12TOE] to set.                  |
| 31<br>FEVTAC12NE    | Force event Auto CMD12 not executed. Forces AUTOC12ERR[AC12NE] to set.                     |

# 16.4.17 Host controller version (eSDHC\_HOSTVER)

The host controller version register contains the version for the vendor and the host controller. All the bits are read-only.

Address: 2\_E000h base + FCh offset = 2\_E0FCh



#### eSDHC\_HOSTVER field descriptions

| Field        | Description                                                                                                             |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------|--|
| 0–15<br>-    | This field is reserved.                                                                                                 |  |
| 16–23<br>VVN | Vendor version number. The host driver should not use this status. The upper and the lower 4-bits indicate the version. |  |
|              | Settings not shown are reserved.                                                                                        |  |
|              | 0x00 Freescale eSDHC version 1.0                                                                                        |  |
|              | 0x01 Freescale eSDHC version 1.1>                                                                                       |  |
|              | 0x10 Freescale eSDHC version 2.0                                                                                        |  |
|              | 0x11 Freescale eSDHC version 2.1                                                                                        |  |
|              | 0x12 F reescale eSDHC version 2.2                                                                                       |  |

### eSDHC\_HOSTVER field descriptions (continued)

| Field        | Description                                                                                                                                |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|
| 24–31<br>SVN | Specification version number. Indicates for the host controller specification version. The upper and the ower 4-bits indicate the version. |  |
|              | Settings not shown are reserved.                                                                                                           |  |
|              | 0x00 SD Host Specification Version 1.0 0x01 SD Host Specification Version 2.0, supports the test event register .                          |  |

# 16.4.18 DMA control register (eSDHC\_DCR)

The DMA control register controls various settings that affect the system response to DMA operations.

Address: 2\_E000h base + 40Ch offset = 2\_E40Ch



eSDHC\_DCR field descriptions

| Field        | Description                                                                                        |  |
|--------------|----------------------------------------------------------------------------------------------------|--|
| 0–15         | This field is reserved.                                                                            |  |
| -            |                                                                                                    |  |
| 16–17<br>PRI | Priority. This field is used to present priority level for AHB arbitration for eSDHC DMA requests. |  |
|              | 00 Level 0 (lowest priority)                                                                       |  |
|              | 01 Level 1                                                                                         |  |
|              | 10 Level 2                                                                                         |  |
|              | 11 Level 3 (highest priority)                                                                      |  |
| 18–24        | This field is reserved.                                                                            |  |
| -            |                                                                                                    |  |

#### eSDHC\_DCR field descriptions (continued)

| Field            | Description                                                                                                                                                                                                                                                                                                                        |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 25<br>SNOOP      | Snoop attribute.                                                                                                                                                                                                                                                                                                                   |  |  |
|                  | 0 DMA transactions are not snooped by the CPU data cache                                                                                                                                                                                                                                                                           |  |  |
|                  | 1 DMA transactions are snooped by the CPU data cache                                                                                                                                                                                                                                                                               |  |  |
| 26–28<br>-       | This field is reserved.                                                                                                                                                                                                                                                                                                            |  |  |
| 29<br>RD_SAFE    | Read safe. This bit should be set only if the target of a read-DMA operation is a well-behaved memory that is not affected by the read operation and returns the same data if read again from the same location. This means that unaligned reading operation can be rounded up to enable more efficient read operations.           |  |  |
|                  | 0 It is not safe to read more bytes that were intended                                                                                                                                                                                                                                                                             |  |  |
|                  | 1 It is safe to read more bytes that were intended                                                                                                                                                                                                                                                                                 |  |  |
| 30<br>RD_PFE     | Read prefetch enable. This bit should be set if the target of read-DMA operation is a well-behaved memory that is not affected by the read operation and returns the same data if read again from the same location. This means that prefetch of data can be done by the internal bus units and it results in faster recompletion. |  |  |
|                  | 0 It is not allowed to prefetch data on DMA read operation                                                                                                                                                                                                                                                                         |  |  |
|                  | 1 It is allowed to prefetch data on DMA read operation                                                                                                                                                                                                                                                                             |  |  |
| 31<br>RD_PF_SIZE | Read prefetch size. Determines the prefetch byte count to be used if RD_PFE is set.                                                                                                                                                                                                                                                |  |  |
|                  | 0 64 bytes prefetch                                                                                                                                                                                                                                                                                                                |  |  |
|                  | 1 32 bytes prefetch                                                                                                                                                                                                                                                                                                                |  |  |

# 16.5 eSDHC functional description

The following sections provide a brief functional description of the major system blocks, including the data buffer, DMA CCB interface, register bank, register bus interface, dual-port memory wrapper, data/command controller, clock and reset manager, and clock generator.

### 16.5.1 Data buffer

The eSDHC uses one configurable data buffer so that data can be transferred between the internal system bus (register bus or CCB bus) and the SD card in an optimized manner to maximize throughput between the two clock domains (the IP peripheral clock and the master clock).

See the figure below for an illustration of the buffer scheme.

The buffer is used as temporary storage for data being transferred between the host system and the card. The burst lengths for read and write are both configurable and can be any value between 1 and 128 words.

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013



Figure 16-25. eSDHC buffer scheme

For a host read operation, when the amount of data exceeds the RD\_WML value, the eSDHC sets PRSSTAT[BREN] and either:

- Issues an interrupt to inform the system to read the data
- When granted CCB access permission, the internal DMA burst-reads RD\_WML number of words

Conversely, for a host write operation, when the amount of buffer spaces exceeds the WR\_WML value, the eSDHC sets PRSSTAT[BWEN] and either:

- Issues an interrupt to inform the system to write data to the buffer
- When granted CCB crossbar access permission, the internal DMA burst-writes WR\_WML number of words into the buffer

### 16.5.1.1 Write operation sequence

There are two ways to write data into the buffer when the user transfers data to the card:

- Processor core polling IRQSTAT[BWR] (interrupt or polling)
- Internal DMA

When the internal DMA is used, the eSDHC does not inform the system before all the required number of bytes are transferred and no error is encountered. When an error occurs during the data transfer, the eSDHC aborts the data transfer and abandons the current block. The host driver should read the content of the DMA system address register to obtain the start address of abandoned data block. If the current data transfer is in multi-block mode, the eSDHC does not automatically send CMD12 even though

XFERTYP[AC12EN] is set. Therefore, in this scenario, the host driver should send CMD12 and restart the write operation from that address. It is recommended that a software reset for data is applied before the transfer is restarted after error recovery.

The eSDHC does not start data transmission until the WML[WR\_WML] number of words of data can be held in the buffer. If the buffer is empty and the host system does not write data in time, the eSDHC stops the SDHC\_CLK to avoid a data buffer underrun situation.

### 16.5.1.2 Read operation sequence

There are two ways to read data from the buffer when transferring data to the card:

- Processor core polling IRQSTAT[BRR] (interrupt or polling)
- Internal DMA

When the internal DMA is used, the eSDHC does not inform the system before all the required number of bytes are transferred and no error is encountered. When an error occurs during the data transfer, the eSDHC aborts the data transfer and abandons the current block. The host driver should read the content of the DMA system address register to obtain the start address of the abandoned data block. If the current data transfer is in multiblock mode, the eSDHC does not automatically send CMD12, even though XFERTYP[AC12EN] is set. Therefore, in this scenario, the host driver should send CMD12 and restart the read operation from that address. It is recommended that a software reset for data is applied before the transfer is restarted after error recovery.

The eSDHC does not start data transmission until the WML[RD\_WML] number of words of data are in the buffer. If the buffer is full and the host system does not read the data in time, the eSDHC stops the SDHC\_CLK to avoid a data buffer overrun situation.

#### 16.5.1.3 Data buffer size

To optimize use of the buffer, the buffer size must be known.

In the eSDHC, the data buffer can hold up to 128 32-bit words, and the read and write watermark levels are each configurable from one to 128 words. The host driver may configure the values according to the system situation and requirements.

During multiblock data transfer, the maximum block length is 4096 bytes, which can satisfy all the requirements from MMC and SD cards. Any block length less than this value is also allowed. The only restriction is from the external card since it may not support such a large block or a partial block access that is not an integer multiple of 512 bytes.

#### eSDHC functional description

For block sizes that are not a multiple of four (that is, not word-aligned), the eSDHC requires stuff bytes at the end of each block because the eSDHC treats each block individually. For example, if the block size is seven bytes and there are twelve blocks to write, the system must write twice for each block. In addition, for each block, the ending byte would be abandoned by the eSDHC because it sends only seven bytes to the card and picks data from the following system write. In total, there would be 24 beats of write access.

#### 16.5.2 DMA CCB interface

The internal DMA implements a DMA engine and CCB master.

When the internal DMA is enabled (that is, XFERTYP[DMAEN] is set), the buffer interrupt status bits remain set if they are enabled. To avoid setting them, clear IRQSTATEN[BWRSEN, BRRSEN]. See Figure 16-26 for an illustration of the DMA CCB interface block. Do not use the internal DMA to read (or write) data when the CPU or an external DMA writes (or reads) the data through the DATPORT register.



Figure 16-26. DMA system bus interface block

### 16.5.2.1 Internal DMA request

When the watermark level is met in the data transfer and the internal DMA is enabled, the data buffer block sends a DMA request to this block.

Meanwhile, the external DMA request is disabled. The delay of response from the internal DMA engine depends on the system bus loading and the priority assigned to the eSDHC. The DMA engine does not respond to the request during its burst transfer, and it is available as soon as the burst is over. When an access on the buffer is made, the data buffer deasserts the request. When the internal DMA accesses the buffer, the data buffer updates its internal buffer pointer. When the watermark level is satisfied, another DMA request is sent.

The data transfer is in the block unit and the last watermark level is always set to the remaining number of words. For example, for a multi-block data read with each block the size of 31 bytes, the burst length is set at six words. After the first burst transfer, if there are more than seven bytes in the buffer, which might include some data from the next block, another DMA read request is sent. This is because the remaining number of words to send for the current block is  $(31 - 6 \times 4) \div 4 = 2$ , and the eSDHC reads two words out of the buffer, with seven valid bytes and one stuff byte automatically added by the eSDHC.

# 16.5.2.2 DMA burst length

Maximum size is the only restriction on DMA burst length for the internal DMA engine.

The burst length for read or write can be one to 128 words. The actual DMA burst length depends on which is smaller: the configured watermark level or the remaining words of the current block.

Consider the example in Internal DMA request. After six words are read, the burst length is two words to complete the 31-byte block. Then the burst length changes back to six words to prepare for the next 31-byte block. The host driver writer may take this variable burst length into account. For a constant burst length, the user may choose to configure the burst length as the divisor of block size.

### 16.5.2.3 CCB Master interface

It is possible that the internal DMA engine fails during data transfer. When an error occurs, the DMA engine stops the transfer and goes into idle state; at the same time, the internal data buffer stops working. IRQSTAT[DMAE] is set to inform the driver.

Once the IRQSTAT[DMAE] interrupt is received, software should send CMD12 to abort the current transfer and read DSADDR[DS\_ADDR] to obtain the start address of the corrupted block. After the DMA error is fixed, the software applies a data reset and restarts the transfer from this address to recover the corrupted block.

### 16.5.3 SD protocol unit

In addition to handling all SD protocol affairs, as well as other miscellaneous functions, the SD protocol unit performs the following:

- Acts as the bridge between the internal buffer and the SD bus
- Sends the command data and its argument serially
- Stores the serial response bit stream into corresponding registers
- Detects the bus state on the SDHC\_DAT[0] line
- Gates off the SD clock when the buffer announces a danger status
- Detects the write-protect state

The SD protocol unit consists of the following four submodules:

- SD transceiver
- SD clock and monitor
- Command agent
- Data agent

#### 16.5.3.1 SD transceiver

In the SD protocol unit, the transceiver is the main control module.

It consists of an FSM and the control module, from which the control signals for all other three modules are generated.

### 16.5.3.2 SD clock and monitor

This module monitors the signal level on all eight data lines and the command lines, directly route the level values into the register bank for the driver to debug with.

The transceiver reports the card insertion state according to the SDHC\_CD\_B state, or signal level on SDHC\_DAT[3] line when PROCTL[D3CD] is set.

The module detects the SDHC\_WP (write protect) line. With the information of SDHC\_WP state, the register bank ignores the command accompanied by write operation, when the SD\_WP switch is on.

If the internal data buffer is in danger and the SD clock must be gated off to avoid buffer over/underrun, this module asserts the gate of output SD clock to shut the clock off. When the buffer danger is eliminated when system access of the buffer catches up, the clock gate of this module is open and the SD clock is active again.

### 16.5.3.3 Command agent

The command agent deals with the transactions on the SDHC\_CMD line.

See the figure below for an illustration of the structure for the command CRC shift register.



Figure 16-27. Command CRC shift register

The CRC polynomials for the SDHC\_CMD are as follows:

1. Generator polynomial: 
$$G(x) = x^7 + x^3 + 1$$
  
 $M(x) = (first bit) x x^n + (second bit) x x^{n-1} + ... + (last bit) x x^0$   
 $CRC[6:0] = Remainder [(M(x) x x^7) \div G(x)]$ 

# 16.5.3.4 Data agent

The data agent handles the transactions on the eight data lines.

The CRC polynomials for the SDHC\_DAT are as follows:

1. Generator polynomial: 
$$G(x) = x^{16} + x^{12} + x^5 + 1$$
  
 $M(x) = (\text{first bit}) \times x^n + (\text{second bit}) \times x^{n-1} + ... + (\text{last bit}) \times x^0$   
 $CRC[15:0] = \text{Remainder} [(M(x) \times x^{16}) \div G(x)]$ 

# 16.5.4 Clock and reset manager

This module controls the reset signals within the eSDHC.

Within eSDHC, there are four types of reset signals, all of which are fed into the clock and reset manager module: hardware reset, software reset for all, software reset for data, and software reset for command. Stable signals are generated inside the module in order to reset all other modules.

In addition, the clock and reset manager module:

- gates off all inside signals,
- monitors the activities of all other modules,
- supplies the clocks for other modules,
- and, when enabled, automatically gates off the corresponding clocks.

### 16.5.5 Clock generator

The clock generator generates the SDHC\_CLK by dividing the internal bus clock into two stages.

Refer to Figure 16-28 for the structure of the divider, in which the term base represents the frequency of the internal bus clock (ccb\_clk/2). Refer to SYSCTL[SDCLKFS] and SYSCTL[DVS] (see System control (eSDHC\_SYSCTL)) to select the divisor values.



Figure 16-28. Two stages of clock divider

The first stage is a prescaler. The frequency of clock output from this stage, DIV, can be base, base/2, base/4, ..., or base/256.

The second stage outputs the actual clock, SDHC\_CLK, as the driving clock for all submodules of SD protocol unit, and the sync FIFOs in Figure 16-25 to synchronize with the data rate from the internal data buffer. It can be div, div/2, div/3,..., or div/16. Thus, the highest frequency of SDHC\_CLK generated by the internal bus clock (ccb\_clk/2) is base while the lowest frequency is base/4096.

### 16.5.6 Card insertion and removal detection

The eSDHC uses the SDHC\_DAT[3] pin or the SDHC\_CD\_B pin to detect card insertion or removal.

- When the SDHC\_DAT[3] pin is used for card detection, the user needs to pull down this pad as a default state. When there is no card on the MMC/SD bus, the SDHC\_DAT[3] is pulled to a low voltage level by default. When any card is inserted to or removed from the socket, the eSDHC detects the logic value changes on the SDHC\_DAT[3] pin and generates an interrupt.
- When the SDHC\_DAT[3] pin is not used for card detection, SDHC\_CD\_B must be connected for card detection. It may be implemented by a GPIO. Whether or not SDHC\_DAT[3] is configured for card detection, SDHC\_CD\_B is always a reference for card detection, either SDHC\_DAT[3] or SDHC\_CD\_B reports the card inserted, the eSDHC informs the host system that a card is inserted, and the interrupt is sent if it is enabled.

# 16.5.7 Power management and wake-up events

In some circumstances, when the clocks to eSDHC are disabled, or when the system is in low-power mode, there are events that require the user to enable the clock and handle the event. These events are called wake-up interrupts. The eSDHC can generate these interrupts even when there are no clocks enabled. The two interrupts that can be used as wake-up events are as follows:

- Card removal interrupt
- Card insertion interrupt

These two wake-up events (or wake-up interrupts) can also be used to wake the system from low-power modes.

#### NOTE

To make the interrupt as a wake-up event when all clocks to the eSDHC are disabled or when the entire system is in low-power mode, the corresponding wake-up enable bit must be set. See Protocol control (eSDHC\_PROCTL) for more information on the eSDHC PROCTL register.

### 16.5.7.1 Setting wake-up events

For the eSDHC to respond to a wake-up event, the software must set the respective wake-up enable bit before the CPU enters sleep mode.

See Protocol control (eSDHC\_PROCTL), for more information on the wake-up enable bits.

Before the software disables the host clock, it should ensure that all of the following conditions have been met:

- No read or write transfer is active
- Data and command lines are not active
- No interrupts are pending
- Internal data buffer is empty

# 16.6 Initialization/application information

All communication between the system and cards is controlled by the host.

The host sends the following types of commands: broadcast and addressed (point-to-point) commands.

Broadcast commands, such as GO\_IDLE\_STATE, SEND\_OP\_COND or ALL\_SEND\_CID, are intended for all cards. In broadcast mode, all cards are in the open-drain mode to avoid bus contention. See Commands for MMC/SD, for the bc and bcr category commands.

After the broadcast command CMD3 is issued, the cards enter standby mode. From this point, addressed commands are used. In this mode, the SDHC\_CMD/SDHC\_DAT I/O pads turn to push-pull mode in order to provide the driving capability for maximum frequency operation. See Commands for MMC/SD, for the ac and adtc category commands.

# 16.6.1 Command send and response receive basic operation

Assuming the data type WORD is an unsigned 32-bit integer, the following flow acts as a guideline for sending a command to the card(s):

For the sake of simplicity, the function wait\_for\_response is implemented here by means of polling. For an effective and formal way, the response is usually checked after the command complete interrupt is received. This ensures the corresponding interrupt status bits are enabled.

For some scenarios, the response timeout is expected. For instance, after all cards respond to CMD3 and enter standby state, there is no response to the host when CMD2 is sent. The host driver should manage false errors similar to this with caution.

### 16.6.2 Card identification mode

When a card is inserted into the socket or the card is reset by the host, the host needs to validate the operation voltage range, identify the cards, and request the cards to publish the relative card address (RCA) or to set the RCA for the MMCs.

#### 16.6.2.1 Card detect

This figure shows a flow diagram of the detection of MMC and SD cards using the eSDHC.



Figure 16-29. Flow diagram for card detection

- 1. Set SYSCTL[RSTA] and wait for it to be cleared.
- 2. Set SYSCTL[PEREN] to enable the clocks and wait for PRSSTAT[PEROFF] to be cleared or enable wakeup event (set PROCTL[WECINS]).
- 3. Set IRQSIGEN[CINSIEN] and IRQSTATEN[CINSEN] to enable card detection interrupt.
- 4. When an IRQSTAT[CINS] interrupt from eSDHC is received, wait for two SD\_CLK cycle and then check PRSSTAT[CINS] to see if the interrupt is caused by card insertion.
- 5. Clear the IRQSIGEN[CINSIEN] and IRQSTATEN[CINSEN] to disable card detection interrupt and ignore all card insertion interrupt afterwards.

#### 16.6.2.2 Reset

The host consists of the following types of reset:

- Hardware reset (card and host), which is driven by POR (power-on reset).
- Software reset (host only), which is proceeded by the write operation on the SYSCTL[RSTD], SYSCTL[RSTC], or SYSCTL[RSTA] bits to reset the data part, command part, or all parts of the host controller, respectively.
- Card reset (card only). The command CMD0, GO\_IDLE\_STATE, is the software reset command for all types of MMCs and SD memory cards. This command sets each card into idle state regardless of the current card state. The cards are initialized with a default relative card address (RCA = 0x0000) and with a default driver stage register setting (lowest speed, highest driving current capability).

After the card is reset, the host must validate the voltage range of the card. See Figure 16-30 for the software flow chart.



Figure 16-30. Flow chart for reset of eSDHC card

The following pseudocode shows how to initialize the eSDHC host controller and the memory card.

```
software_reset()
          Configure the I/O muxes to select SD signals;
          set_bit(SYSCTL, RSTA);
                                                              // software reset the host
          set SYSCTL[DTOCV and SDCLKFS];
                                                          // get the SDHC_CLK of frequency
around 400 kHz
         poll PRSSTAT[CIHB and CDIHB];
                                                             // wait until both bits are
cleared
         set_bit(SYSCTRL, INTIA);
                                                                // send 80 clock ticks for
card to power-up
         If the card is SD/MMC
                send_command(CMD_GO_IDLE_STATE, <other parameters>); // reset the card with
CMD0
```

### 16.6.2.3 Voltage validation

All cards should be able to establish communication with the host by using any operation voltage in the maximum allowed voltage range, as specified in this standard.

However, the supported minimum and maximum values for  $V_{DD}$  are defined in the operation conditions register (OCR) and may not cover the whole range. Cards that store the CID (card identification) and CSD data in the preloaded memory are only able to communicate this information under data transfer  $V_{DD}$  conditions. This means that if the host and card have different  $V_{DD}$  ranges, the card is not able to complete the identification cycle, nor is it able to send CSD data.

Therefore, a special command is available, as follows:

- SEND\_OP\_CONT (CMD1 for MMC),
- SD\_SEND\_OP\_CONT (ACMD41 for SD Memory)

The voltage validation procedure is designed to provide a mechanism to identify and reject cards that do not match the  $V_{DD}$  range(s) desired by the host. This is accomplished when the host sends the desired  $V_{DD}$  voltage window as the operand of this command. Cards that cannot perform data transfer in the specified range must discontinue any further bus operations and enter the inactive state.

By omitting the voltage range in the command, the host can query each card and determine the common voltage range before sending out-of-range cards into the inactive state. This query should be used if the host is able to select a common voltage range or if a notification should be sent to the system when a non-usable card in the stack is detected.

### 16.6.2.4 Card registry

Card registry on the MMC and SD cards differs.

SD card registry is as follows:

#### **NOTE**

The identification process starts at a clock rate lower than 400 kHz and a power voltage higher than 2.7 V, as defined by the card specification. At this time, the SDHC\_CMD line output drives are push-pull drivers instead of open-drain.

- 1. After the bus is activated, the host requests the cards to send their valid operation conditions. The response to ACMD41 is the operation condition register of the card.
- 2. The host should send the same command to all of the new cards in the system. Incompatible cards are placed into the inactive state.

- 3. The host then issues the command, ALL\_SEND\_CID (CMD2), to each card to get its CID. Cards that are currently unidentified (that is, in ready state), send their CID number as the response.
- 4. After the CID is sent by the card, the card goes into the identification state.
- 5. The host then issues Send\_Relative\_Addr (CMD3), requesting the card publish a new relative card address (RCA) that is shorter than CID. This RCA is used to address the card for future data transfer operations.
- 6. Once the RCA is received, the card changes to standby state. At this point, if the host wants the card to have an alternative RCA number, it may ask the card to publish a new number by sending another Send\_Relative\_Addr command to the card. The last published RCA is the actual RCA of the card.
- 7. The host repeats the identification process with CMD2 and CMD3 for each card in the system until the last CMD2 gets no response from the cards in system.

MMC card registry is as follows:

#### **NOTE**

For MMC operation, the host starts the card identification process in open-drain mode with the identification clock rate lower than 400 kHz and the power voltage higher than 2.7 V. The open-drain driver stages on the SDHC\_CMD line allow for parallel card operation during card identification.

- 1. After the bus is activated, the host requests the cards to send their valid operation conditions (CMD1). The response to CMD1 is the wired-OR operation on the condition restrictions of all cards in the system. Incompatible cards are sent into inactive state.
- 2. The host then issues the broadcast command All\_Send\_CID (CMD2), asking all cards for their unique CID number. All unidentified cards (the cards in ready state) simultaneously start sending their CID numbers serially, while bit-wise monitoring their outgoing bit stream. Those cards whose outgoing CID bits do not match the corresponding bits on the command line in any one of the bit periods stop sending their CID immediately and must wait for the next identification cycle. Since the CID is unique for each card, only one card can successfully send its full CID to the host. This card then goes into identification state.
- 3. Thereafter, the host issues Set\_Relative\_Addr (CMD3) to assign to this card a relative card address (RCA).
- 4. Once the RCA is received, the card state changes to standby state, the card does not react in further identification cycles, and its output driver switches from open-drain to push-pull.
- 5. The host repeats the process, namely CMD2 and CMD3, until the host receives a time-out condition to recognize completion of the identification process.

#### 16.6.3 Card access

The following sections describe the supported access modes with external cards.

#### 16.6.3.1 Block write

This section describes the process of writing data to external cards in block mode.

#### 16.6.3.1.1 Normal write

During block write (CMD24-27), one or more blocks of data are transferred from the host to the card; the host appends a CRC to the end of each block.

If the CRC fails, the card should indicate the failure on the SDHC\_DAT line (see below). The transferred data is discarded and not written, and all further transmitted blocks (in multi-block write mode) are ignored.

When the host uses partial blocks whose accumulated length is not block-aligned and block misalignment is not allowed (CSD parameter WRITE\_BLK\_MISALIGN is not set), the card detects the block misalignment error and aborts programming before the beginning of the first misaligned block. The card sets the ADDRESS\_ERROR error bit in the status register, as defined in the MMC/SD specification, and then waits in the receivedata state for a stop command, ignoring all further data transfers. The write operation is also aborted when the host attempts to write over a write-protected area.

For MMC and SD cards, programming the CID and CSD registers does not require a previous block length setting. The transferred data is also CRC-protected. If a part of the CSD or CID register is stored in the ROM, this unchangeable section must match the corresponding section of the receive buffer. If this match fails, the card reports an error and does not change any register content.

Some cards may require a long and unpredictable period of time to write a block of data. After receiving a block of data and completing the CRC check, the card begins writing. When its write buffer is full and unable to accept new data from a new WRITE\_BLOCK command, the card holds the SDHC\_DAT line low. The host may poll the status of the card with a SEND\_STATUS command (CMD13) cards, at any time and the card responds with its status. The card status indicates whether the card can accept new data or if the write process is still in progress. The host may deselect the card by issuing CMD7 (to select a different card) to change the card into the standby state and release the

SDHC\_DAT line without interrupting the write operation. When re-selecting the card, the host reactivates the busy indication by pulling SDHC\_DAT low when programming is still in progress and the write buffer is unavailable.

For the sake of simplicity, the software flow described below incorporates the internal DMA, and the write operation is a multi-block write with Auto CMD12 enabled. For the CPU polling status method and different transfer natures, remove the internal DMA part of the procedure and insert alternative steps.

- 1. Check the card status and wait until the card is ready for data.
- 2. Set the card block length.
  - For MMC/SD cards, use SET\_BLOCKLEN (CMD16).
- 3. Set eSDHC BLKATTR[BLKSIZE] to the same block length set in the card in step 2.
- 4. Set eSDHC BLKATTR[BLKCNT] with the number of blocks to send.
- 5. Disable the buffer write ready interrupt, configure the DMA setting, and enable the eSDHC DMA when sending the command with data transfer. Set XFERTYP[AC12EN].
- 6. Wait for the transfer complete interrupt.
- 7. Check the status bit to see if a read CRC error or any other errors occurred between sending Auto CMD12 and receiving the response.

### 16.6.3.1.2 Write with pause

The write operation can be paused during the transfer.

Instead of stopping the SDHC\_CLK at any time to pause all the operations which is also inaccessible to the host driver, the driver can set PROCTL[SABGREQ] to pause the transfer between the data blocks. Because there is no timeout condition in a write operation during the data blocks, a write operation to the cards can be paused in this way and if line SDHC\_DAT0 is not required to de-assert to release busy state.

Similar to the flow described in Normal write, the write with pause is shown with the same type of write operations:

- 1. Check the card status and wait until card is ready for data.
- 2. Set the card block length.
  - For MMC/SD cards, use SET\_BLOCKLEN (CMD16)
- 3. Set the eSDHC BLKATTR[BLKSIZE] to the same as the block length set in the card in step 2.
- 4. Set eSDHC BLKATTR[BLKCNT] with the number of blocks to send.
- 5. Disable the buffer write ready interrupt, configure the DMA setting, and enable the eSDHC DMA when sending the command with data transfer. Set XFERTYP[AC12EN].
- 6. Set PROCTL[SABGREQ].

#### Initialization/application information

- 7. Wait for the transfer complete interrupt.
- 8. Clear PROCTL[SABGREQ].
- 9. Check the status bit to see if a read CRC error occurred.
- 10. Set PROCTL[CREQ] to continue the read operation.
- 11. Wait for the transfer complete interrupt.
- 12. Check the status bit to see if a read CRC error or any other errors occurred between sending Auto CMD12 and receiving the response.

The number of blocks left during the data transfer is accessible by reading the content of BLKATTR[BLKCNT]. Due to the data transfers and setting PROCTL[SABGREQ] are concurrent, along with the delay of register read and the register setting, the actual number of blocks left may not be the same as the value read earlier. The driver should read the value of BLKATTR[BLKCNT] after the transfer is paused and the transfer complete interrupt is received.

It is also possible that the transfer of the last block begins when the stop-at-block-gap request is sent to the buffer. In this case, the next block gap is the actual end of the transfer, and therefore, the request is ignored. The driver should treat this as a non-pause transfer and a common write operation.

When the write operation is paused, the data transfer inside the host system does not stop and the transfer remains active until the data buffer is full.

### 16.6.3.2 Block read

This section discusses normal read and read with pause.

#### 16.6.3.2.1 Normal read

For block reads, the basic unit of a data transfer is a block whose maximum size is stored in areas defined in corresponding card specifications.

A CRC is appended to the end of each block, ensuring data transfer integrity. CMD17, CMD18, CMD53, and so on, can initiate a block read. After completing the transfer, the card returns to the transfer state.

For multiblock reads, data blocks are continuously transferred until a stop command is issued. If the host uses partial blocks whose accumulated length is not block aligned and block misalignment is not allowed, the card that does not support partial block length, should detect the block misalignment at the beginning of the first misaligned block and report the error, depending on its card type.

For simplicity, the software flow described below incorporates the internal DMA, and the read operation is a multiblock read with Auto CMD12 enabled. For the other method (CPU polling status) and different transfer nature, the internal DMA part should be removed and the alternative steps are straightforward.

- 1. Check the card status and wait until the card is ready for data.
- 2. Set the card block length.
  - For MMC/SD cards, use SET\_BLOCKLEN (CMD16)
- 3. Set eSDHC BLKATTR[BLKSIZE] to the same as the block length set in the card in step 2.
- 4. Set eSDHC BLKATTR[BLKCNT] with the number of blocks to send.
- 5. Disable the buffer read ready interrupt, configure the DMA setting, and enable the eSDHC DMA when sending the command with data transfer. Set XFERTYP[AC12EN].
- 6. Wait for the transfer complete interrupt.
- 7. Check the status bit to see if a read CRC error or any other errors occurred between sending Auto CMD12 and receiving the response.

### 16.6.3.2.2 Read with pause

In general, the read operation is not able to pause.

Similarly to the flow described in Normal read, the read with pause is shown with the following read operations:

- 1. Set PROCTL[RWCTL].
- 2. Check the card status and wait until the card is ready for data.
- 3. Set the card block length.
  - Fore MMC/SD cards, use SET\_BLOCKLEN (CMD16)
- 4. Set eSDHC BLKATTR[BLKSIZE] to the same as the block length set in the card in Step 2.
- 5. Set eSDHC BLKATTR[BLKCNT] with the number of blocks to send.
- 6. Disable the buffer read ready interrupt, configure the DMA setting, and enable the eSDHC DMA when sending the command with data transfer. Set XFERTYP[AC12EN].
- 7. Set PROCTL[SABGREQ].
- 8. Wait for the transfer complete interrupt.
- 9. Clear PROCTL[SABGREQ].
- 10. Check the status bit to see if a read CRC error occurred.
- 11. Set PROCTL[CREQ] to continue the read operation.
- 12. Wait for the transfer complete interrupt.
- 13. Check the status bit to see if a read CRC error or any other errors occurred between sending Auto CMD12 and receiving the response.

#### Initialization/application information

Similar to the write operation, it is possible to meet the ending block of the transfer when paused. In this case, the eSDHC ignores the stop-at-block-gap request and treats it as a command read operation.

Unlike the write operation, there is no remaining data inside the buffer when the transfer is paused. All data received before the pause is transferred to the host system; the internal data buffer is not flushed.

#### 16.6.3.3 Transfer error

This section discusses CRC errors, internal DMA errors, and Auto CMD12 errors.

#### 16.6.3.3.1 CRC error

At the end of a block transfer, a write CRC status error or read CRC error may occur.

For this type of error, the last block received should be discarded because the integrity of the data block is not guaranteed. It is recommended that the following data blocks be discarded and the block be retransferred from the corrupted one. For a multiblock transfer, the host driver should issue CMD12 to abort the current process and start the transfer by a new data command. In this scenario, even when the XFERTYP[AC12EN, BCEN] are set, the eSDHC does not automatically send CMD12 because the last block is not transferred. On the other hand, if it is within the last block that CRC error occurs, Auto CMD12 is sent by the eSDHC. In this case, the driver should resend or re-obtain the last block with a single block transfer.

#### 16.6.3.3.2 Internal DMA error

During the data transfer with the internal DMA, if the DMA engine encounters an error on the platform bus, the DMA operation is aborted and a DMA error interrupt is sent to the host system.

When acknowledged by such an interrupt, the driver should calculate the start address of the data block where the error occurred. The start address can be calculated by either of the following methods:

- Read the DSADDR[DSADDR] field. The error occurs during the previous burst. Therefore, by taking the block size, the previous burst length, and the start address of the next burst transfer into account, one can obtain the start address of the corrupted block.
- Read the BLKATTR[BLKCNT] field. The start address of the corrupted block can be calculated by the number of blocks left, the total number to transfer, the start address of transfer, and the size of each block. However, if BCEN is not set, the

contents of the block attribute register does not change and this method does not work.

When a DMA error occurs, it is recommended to abort the current transfer by means of CMD12 (for multi-block transfer), apply a reset for data, and restart the transfer from the corrupted block to recover the error.

#### 16.6.3.3.3 Auto CMD12 error

After the last block of a multi-block transfer is sent or received and XFERTYP[AC12EN] is set when the data transfer is initiated by the data command, the eSDHC automatically sends CMD12 to the card to stop the transfer.

When an error occurs at this point, the host driver should respond as follows:

| Auto CMD12 response timeout           | It is not certain whether the command has been accepted by the card or not. The driver should clear the Auto CMD12 error status bits and resend CMD12 until it is accepted by the card. |  |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Auto CMD12 response CRC error         | Because CMD12 has been received by the card, the card aborts the transfer. The driver may ignore the error and clear the error status bit.                                              |  |
| Auto CMD12 conflict error or not sent | The command was not sent. Therefore, the driver should send CMD12 manually.                                                                                                             |  |

### 16.6.3.4 Card interrupt

The external cards can inform the host controller through the use of special signals.

### 16.6.4 Switch function

MMCs transferring data with a bus width other than one-bit wide is a new feature added to the MMC specification.

The high-speed timing mode for all card devices is also newly-defined in recent various card specifications. To enable these new features, a type of switch command should be issued by the host driver.

For SD cards, the high-speed mode is queried and enabled by CMD6 (with the mnemonic symbol as SWITCH\_FUNC); for MMCs, the high-speed mode is queried by CMD8 and enabled by CMD6 (with the mnemonic symbol as SWITCH).

The 4-bit and 8-bit bus width of MMC is also enabled by the SWITCH command, but with a different argument.

#### Initialization/application information

These new functions can also be disabled by software reset, but such manner of restoring to normal mode is not recommended because a complete identification process is needed before the card is ready for data transfer.

### 16.6.4.1 Query, enable and disable SD high speed mode

```
enable_sd_high_speed_mode(void)
          set BLKATTR[BLKCNT] to 1 (block), set BLKATTR[BLKSIZE] to 64 (bytes);
          send CMD6, with argument 0xFFFFF1 and read 64 bytes of data accompanying the R1
                    response;
          wait data transfer done bit is set;
          check if the bit 401 of received 512 bit is set;
          if (bit 401 is '0') report the SD card does not support high speed mode and return;
          send CMD6, with argument 0x80FFFFF1 and read 64 bytes of data accompanying the R1
                    response;
          check if the bit field 379~376 is 0xF;
          if (the bit field is 0xF) report the function switch failed and return;
          change clock divisor value or configure the system clock feeding into eSDHC to
generate
                    the card_clk of around 50MHz;
          (data transactions like normal peers)
disable_sd_high_speed_mode(void)
          set BLKCNT field to 1 (block), set BLKSIZE field to 64 (bytes);
          send CMD6, with argument 0x80FFFFF0 and read 64 bytes of data accompanying the R1
                    response;
          check if the bit field 379~376 is 0xF;
          if (the bit field is 0xF) report the function switch failed and return;
          change clock divisor value or configure the system clock feeding into eSDHC to
generate
                    the card_clk of the desired value below 25MHz;
          (data transactions like normal peers)
```

### 16.6.4.2 Query, enable and disable MMC high speed mode

```
enable_mmc_high_speed_mode(void)
{
    send CMD9 to get CSD value of MMC;
    check if the value of SPEC_VER field is 4 or above;
    if (SPEC_VER value is less than 4) report the MMC does not support high speed mode and

    return;
    set BLKCNT field to 1 (block), set BLKSIZE field to 512 (bytes);
    send CMD8 to get EXT_CSD value of MMC;
    extract the value of CARD_TYPE field to check the 'high speed mode' in this MMC is

    26MHz or 52MHz;
    send CMD6 with argument 0x1B90100;
    send CMD13 to wait card ready (busy line released);
    send CMD8 to get EXT_CSD value of MMC;
    check if HS_TIMING byte (byte number 185) is 1;
    if (HS_TIMING is not 1) report MMC switching to high speed mode failed and return;
```

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

```
change clock divisor value or configure the system clock feeding into eSDHC to generate

the card_clk of around 26MHz or 52MHz according to the CARD_TYPE;
(data transactions like normal peers)
}
disable_mmc_high_speed_mode(void)
{
    send CMD6 with argument 0x2B90100;
    set BLKCNT field to 1 (block), set BLKSIZE field to 512 (bytes);
    send CMD8 to get EXT_CSD value of MMC;
    check if HS_TIMING byte (byte number 185) is 0;
    if (HS_TIMING is not 0) report the function switch failed and return;
    change clock divisor value or configure the system clock feeding into eSDHC to generate

    the card_clk of the desired value below 20MHz;
    (data transactions like normal peers)
}
```

#### 16.6.4.3 Set MMC bus width

### 16.6.5 Commands for MMC/SD

See the table below for a list of commands for the MMC/SD cards.

See the corresponding specifications for details about the command information.

Four kinds of commands control the MMC, as follows:

- 1. Broadcast commands (bc)-no response
- 2. Broadcast commands with response (bcr)-response from all cards simultaneously
- 3. Addressed (point-to-point) commands (ac)-no data transfer on SDHC\_DAT
- 4. Addressed (point-to-point) data transfer commands (adtc)

| Table 16-35. | Commands | for MMC/SD |
|--------------|----------|------------|
|--------------|----------|------------|

| CMD INDEX | Туре | Argument          | Resp | Abbreviation | Description <sup>1</sup>                          |
|-----------|------|-------------------|------|--------------|---------------------------------------------------|
| CMD0      | bc   | [31:0] stuff bits | -    |              | Resets all MMC and SD memory cards to idle state. |

Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX           | Туре | Argument                                                                                | Resp | Abbreviation               | Description <sup>1</sup>                                                                                                                                                          |
|---------------------|------|-----------------------------------------------------------------------------------------|------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD1                | bcr  | [31:0] OCR without<br>busy                                                              | R3   | SEND_OP_COND               | Asks all MMCs and SD memory cards in idle state to send their operation conditions register contents in the response on the SDHC_CMD line.                                        |
| CMD2                | bcr  | [31:0] stuff bits                                                                       | R2   | ALL_SEND_CID               | Asks all cards to send their CID numbers on the SDHC_CMD line.                                                                                                                    |
| CMD3 <sup>(1)</sup> | ac   | [31:6] RCA                                                                              | R1   | SET/<br>SEND_RELATIVE_ADDR | Assigns relative address to the card.                                                                                                                                             |
|                     |      | [15:0] stuff bits                                                                       |      |                            |                                                                                                                                                                                   |
| CMD4                | bc   | [31:0] DSR                                                                              | -    | SET_DSR                    | Programs the DSR of all cards.                                                                                                                                                    |
|                     |      | [15:0] stuff bits                                                                       |      |                            |                                                                                                                                                                                   |
| CMD6 <sup>(2)</sup> | adtc | [31] Mode                                                                               | R1   | SWITCH_FUNC                | Checks switch ability (mode 0) and                                                                                                                                                |
|                     |      | 0: Check function                                                                       |      |                            | switch card function (mode 1). Refer to SD Physical Specification version                                                                                                         |
|                     |      | 1: Switch function<br>[30:8] Reserved for<br>function groups 6 ~ 3<br>(All 0 or 0xFFFF) |      |                            | 2.0 for details.                                                                                                                                                                  |
|                     |      | [7:4] Function group1 for command system                                                |      |                            |                                                                                                                                                                                   |
|                     |      | [3:0] Function group2 for access mode                                                   |      |                            |                                                                                                                                                                                   |
| CMD6 <sup>(3)</sup> | ac   | [31:26] Set to 0                                                                        | R1b  | SWITCH                     | Switches the mode of operation of the selected card or modifies the EXT_CSD registers. Refer to the MultiMediaCard System Specification version 4.0 final draft 2 for details.    |
|                     |      | [25:24] Access                                                                          |      |                            |                                                                                                                                                                                   |
|                     |      | [23:16] Index                                                                           |      |                            |                                                                                                                                                                                   |
|                     |      | [15:8] Value                                                                            |      |                            |                                                                                                                                                                                   |
|                     |      | [7:3] Set to 0                                                                          |      |                            |                                                                                                                                                                                   |
|                     |      | [2:0] Cmd Set                                                                           |      |                            |                                                                                                                                                                                   |
| CMD7                | ac   | [31:6] RCA                                                                              | R1b  | SELECT/DESELECT_CARD       | Command toggles a card between the stand-by and transfer states or                                                                                                                |
|                     |      | [15:0] stuff bits                                                                       |      |                            | between the programming and disconnect states. In both cases, the card is selected by its own relative address and gets deselected by any other address; address 0 deselects all. |
| CMD8                | bcr  | [31:12] reserved bits<br>[11:8] supply<br>voltage(VHS) [7:0]<br>check pattern           | R7   | SEND_IF_COND               | Sends SD Memory Card interface condition, which includes host supply voltage information and asks the card whether card supports voltage. Reserved bits shall be set to '0'.      |
| CMD8                | adtc | [31:0] stuff bits                                                                       | R1   | SEND_EXT_CSD               | The card sends its EXT_CSD register as a block of data, with block size of 512 bytes.                                                                                             |
| CMD9                | ac   | [31:6] RCA                                                                              | R2   | SEND_CSD                   | Addressed card sends its card-                                                                                                                                                    |
|                     |      | [15:0] stuff bits                                                                       |      |                            | specific data (CSD) on the SDHC_CMD line.                                                                                                                                         |

# Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX | Туре   | Argument                        | Resp | Abbreviation         | Description <sup>1</sup>                                                                                                                                                                                                                     |
|-----------|--------|---------------------------------|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD10     | ac     | [31:6] RCA<br>[15:0] stuff bits | R2   | SEND_CID             | Addressed card sends its card-<br>identification (CID) on the<br>SDHC_CMD line.                                                                                                                                                              |
| CMD11     | adtc   | [31:0] data address             | R1   | READ_DAT_UNTIL_STOP  | Reads data stream from the card starting at the given address until STOP_TRANSMISSION is received.                                                                                                                                           |
| CMD12     | ac     | [31:0] stuff bits               | R1b  | STOP_TRANSMISSION    | Forces the card to stop transmission.                                                                                                                                                                                                        |
| CMD13     | ac     | [31:6] RCA                      | R1   | SEND_STATUS          | Addressed card sends its status                                                                                                                                                                                                              |
|           |        | [15:0] stuff bits               |      |                      | register.                                                                                                                                                                                                                                    |
| CMD14     | Reserv | red                             |      | I                    |                                                                                                                                                                                                                                              |
| CMD15     | ac     | [31:6] RCA<br>[15:0] stuff bits | -    | GO_INACTIVE_STATE    | Sets the card to inactive state in order to protect the card stack against communication breakdowns.                                                                                                                                         |
| CMD16     | ac     | [31:0] block length             | R1   | SET_BLOCKLEN         | Sets the block length (in bytes) for all following block commands (read and write). Default block length is specified in the CSD.                                                                                                            |
| CMD17     | adtc   | [31:0] data address             | R1   | READ_SINGLE_BLOCK    | Reads a block of the size selected by the SET_BLOCKLEN command.                                                                                                                                                                              |
| CMD18     | adtc   | [31:0] data address             | R1   | READ_MULTIPLE_BLOCK  | Continuously transfers data blocks from card to host until interrupted by a stop command.                                                                                                                                                    |
| CMD19     | Reserv | ed                              | '    |                      |                                                                                                                                                                                                                                              |
| CMD20     | adtc   | [31:0] data address             | R1   | WRITE_DAT_UNTIL_STOP | Writes data stream from the host starting at the given address until the STOP_TRANSMISION command is received.                                                                                                                               |
| CMD21-23  | Reserv | ed                              | •    |                      |                                                                                                                                                                                                                                              |
| CMD24     | adtc   | [31:0] data address             | R1   | WRITE_BLOCK          | Writes a block of the size selected by the SET_BLOCKLEN command.                                                                                                                                                                             |
| CMD25     | adtc   | [31:0] data address             | R1   | WRITE_MULTIPLE_BLOCK | Continuously writes blocks of data until the STOP_TRANSMISSION command is received.                                                                                                                                                          |
| CMD26     | adtc   | [31:0] stuff bits               | R1   | PROGRAM_CID          | Programming of the card identification register. This command should be issued only once per card. The card contains hardware to prevent this operation after the first programming. Normally this command is reserved for the manufacturer. |
| CMD27     | adtc   | [31:0] stuff bits               | R1   | PROGRAM_CSD          | Programming of the programmable bits of the CSD.                                                                                                                                                                                             |
| CMD28     | ac     | [31:0] data address             | R1b  | SET_WRITE_PROT       | If the card has write-protection features, this command sets the write protection bit of the addressed group. The properties of write protection are coded in the card-specific data (WP_GRP_SIZE).                                          |

Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX | Туре   | Argument                                                                                 | Resp | Abbreviation              | Description <sup>1</sup>                                                                                                                                                                                                                                                                                                  |
|-----------|--------|------------------------------------------------------------------------------------------|------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD29     | ac     | [31:0] data address                                                                      | R1b  | CLR_WRITE_PROT            | If the card provides write-protection features, this command clears the write protection bit of the addressed group.                                                                                                                                                                                                      |
| CMD30     | adtc   | [31:0] write protect<br>data address                                                     | R1   | SEND_WRITE_PROT           | If the card provides write-protection features, this command asks the card to send the status of the write-protection bits.                                                                                                                                                                                               |
| CMD31     | Reserv | red                                                                                      | •    |                           |                                                                                                                                                                                                                                                                                                                           |
| CMD32     | ac     | [31:0] data address                                                                      | R1   | TAG_SECTOR_START          | Sets the address of the first sector of the erase group.                                                                                                                                                                                                                                                                  |
| CMD33     | ac     | [31:0] data address                                                                      | R1   | TAG_SECTOR_END            | Sets the address of the last write block of the continuous range to be erased.                                                                                                                                                                                                                                            |
| CMD34     | ac     | [31:0] data address                                                                      | R1   | UNTAG_SECTOR              | Removes one previously selected sector from the erase selection.                                                                                                                                                                                                                                                          |
| CMD35     | ac     | [31:0] data address                                                                      | R1   | TAG_ERASE_GROUP_STAR<br>T | Sets the address of the first erase group within a range to be selected for erase.                                                                                                                                                                                                                                        |
| CMD36     | ac     | [31:0] data address                                                                      | R1   | TAG_ERASE_GROUP_END       | Sets the address of the last erase group within a continuous range to be selected for erase.                                                                                                                                                                                                                              |
| CMD37     | ac     | [31:0] data address                                                                      | R1   | UNTAG_ERASE_GROUP         | Removes one previously selected erase group from the erase selection.                                                                                                                                                                                                                                                     |
| CMD38     | ac     | [31:0] stuff bits                                                                        | R1b  | ERASE                     | Erase all previously selected sectors.                                                                                                                                                                                                                                                                                    |
| CMD39     | ac     | [31:0] RCA<br>[15] register write flag<br>[14:8] register address<br>[7:0] register data | R4   | FAST_IO                   | Used to write and read 8-bit (register) data fields. The command address a card and a register and provides the data for writing if the write flag is set. The R4 response contains data read from the address register. This command accesses application dependent registers which are not defined in the MMC standard. |
| CMD40     | bcr    | [31:0] stuff bits                                                                        | R5   | GO_IRQ_STATE              | Sets the system into interrupt mode.                                                                                                                                                                                                                                                                                      |
| CMD41     | Reserv | red                                                                                      | •    | •                         |                                                                                                                                                                                                                                                                                                                           |
| CDM42     | adtc   | [31:0] stuff bits                                                                        | R1b  | LOCK_UNLOCK               | Used to set/reset the password or lock/unlock the card. The size of the data block is set by the SET_BLOCK_LEN command.                                                                                                                                                                                                   |
| CMD43-51  | Reserv | red                                                                                      |      |                           |                                                                                                                                                                                                                                                                                                                           |
| CMD52     | ac     | [31:0] stuff bits                                                                        | R5   | IO_RW_DIRECT              | Access a single register within the total 128 Kbytes of register space in any I/O function.                                                                                                                                                                                                                               |
| CMD53     | ac     | [31:0] stuff bits                                                                        | R5   | IO_RW_EXTENDED            | Access a multiple I/O register with a single command, it allows the reading or writing of a large number of I/O registers.                                                                                                                                                                                                |

Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX     | Туре     | Argument                                   | Resp      | Abbreviation                 | Description <sup>1</sup>                                                                                                                                                                                    |  |
|---------------|----------|--------------------------------------------|-----------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CMD54         | Reserved |                                            |           |                              |                                                                                                                                                                                                             |  |
| CMD55         | ac       | [31:16] RCA<br>[15:0] stuff bits           | R1        | APP_CMD                      | Indicates to the card that the next command is an application specific command rather that a standard command.                                                                                              |  |
| CMD56         | adtc     | [31:1] stuff bits<br>[0]: RD/WR            | R1b       | GEN_CMD                      | Used either to transfer a data block to the card or to get a data block from the card for general-purpose or application-specific commands. The size of the data block is set by the SET_BLOCK_LEN command. |  |
| CMD57-63      | Reserv   | ed                                         |           |                              |                                                                                                                                                                                                             |  |
| ACMDs should  | be pred  | ceded with the APP_CM                      | D comm    | and                          |                                                                                                                                                                                                             |  |
| (Commands lis | ted belo | w are for SD cards only                    | . Other S | SD commands not listed below | are not supported by this module)                                                                                                                                                                           |  |
| ACMD6         | ac       | [31:2] stuff bits [1:0] bus width          | R1        | SET_BUS_WIDTH                | Defines the data bus width (00 = 1 bit or 10 = 4 bit bus) to be used for data transfer. The allowed data bus widths are given in DCR register.                                                              |  |
| ACMD13        | adtc     | [31:0] stuff bits                          | R1        | SD_STATUS                    | Send the SD memory card status.                                                                                                                                                                             |  |
| ACMD18        | adtc     | [31:0] stuff bits                          | R1        | SECURE_READ_MULTI_<br>BLOCK  | Protected Area Access Command:  Reads continuously transfer data blocks from Protected Area of SD Memory Card.  Refer to Security Specification                                                             |  |
|               |          |                                            |           |                              | Version 2.00 for more details.                                                                                                                                                                              |  |
| ACMD22        | adtc     | [31:0] stuff bits                          | R1        | SEND_NUM_WR_<br>SECTORS      | Send the number of the written (without errors) sectors. Responds with 32 bit + CRC data block.                                                                                                             |  |
| ACMD23        | ac       | [31:23] stuff bits [22:0] number of blocks | R1        | SET_WR_BLK_ERASE_<br>COUNT   | -                                                                                                                                                                                                           |  |
| ACMD25        | adtc     | [31:0] stuff bits                          | R1        | SECURE_WRITE_MULTI_          | Protected Area Access Command:                                                                                                                                                                              |  |
|               |          |                                            |           | BLOCK                        | Writes continuously transfer data blocks to Protected Area of SD memory card.                                                                                                                               |  |
|               |          |                                            |           |                              | Refer to Security Specification Version 2.00 for more details.                                                                                                                                              |  |
| ACMD26        | adtc     | [31:0] stuff bits                          | R1        | SECURE_WRITE_MKB             | System Area Access Command:                                                                                                                                                                                 |  |
|               |          |                                            |           |                              | Overwrite the existing Media Key<br>Block (MKB) on System Area of SD<br>Memory Card with new MKB. This<br>command is used in dynamic update<br>MKB scheme.                                                  |  |
|               |          |                                            |           |                              | Refer to Security Specification Version 2.00 for more details.                                                                                                                                              |  |

Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX | Туре | Argument           | Resp | Abbreviation        | Description <sup>1</sup>                                                                                                                                                                                                             |
|-----------|------|--------------------|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACMD38    | ac   | [31:0] stuff bits  | R1b  | SECURE_ERASE        | Protected Area Access Command:                                                                                                                                                                                                       |
|           |      |                    |      |                     | Erase a specified region of the Protected Area of SD Memory Card.                                                                                                                                                                    |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD41    | bcr  | [31:0] OCR         | R3   | SD_APP_OP_COND      | Asks the accessed card to send its operating condition register (OCR) content in the response on the SDHC_CMD line.                                                                                                                  |
| ACMD42    | ac   | -                  | R1   | SET_CLR_CARD_DETECT | -                                                                                                                                                                                                                                    |
| ACMD43    | adtc | [31:24]Unit_Count: | R1   | GET_MKB             | Reads Media Key Block from System Area of SD Memory Card.                                                                                                                                                                            |
|           |      | [15:0]Unit_Offset: |      |                     | <ul> <li>Unit_Count specifies the Number of units to read. (Here, a unit = 512 bytes (fixed).)</li> <li>MKB_ID specifies the application unique number.</li> <li>Unit_Offset specifies the start address(offset) to read.</li> </ul> |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD44    | adtc | [31:0] stuff bits  | R1   | GET_MID             | Reads Media ID from the System Area of SD Memory Card.                                                                                                                                                                               |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD45    | adtc | [31:0] stuff bits  | R1   | SET_CER_RN1         | AKE Command:                                                                                                                                                                                                                         |
|           |      |                    |      |                     | Writes random number RN1 as challenge1 in AKE process.                                                                                                                                                                               |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD46    | adtc | [31:0] stuff bits  | R1   | GET_CER_RN2         | AKE Command:                                                                                                                                                                                                                         |
|           |      |                    |      |                     | Reads random number RN2 as challenge2 in AKE process.                                                                                                                                                                                |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD47    | adtc | [31:0] stuff bits  | R1   | SET_CER_RES2        | AKE Command:                                                                                                                                                                                                                         |
|           |      |                    |      |                     | Writes RES2 as response2 to RN2 in AKE process.                                                                                                                                                                                      |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |
| ACMD48    | adtc | [31:0] stuff bits  | R1   | GET_CER_RES1        | AKE Command:                                                                                                                                                                                                                         |
|           |      |                    |      |                     | Reads RES1 as response1 to RN1 in AKE process.                                                                                                                                                                                       |
|           |      |                    |      |                     | Refer to Security Specification Version 2.00 for more details.                                                                                                                                                                       |

Table 16-35. Commands for MMC/SD (continued)

| CMD INDEX | Туре | Argument          | Resp | Abbreviation       | Description <sup>1</sup>                                          |
|-----------|------|-------------------|------|--------------------|-------------------------------------------------------------------|
| ACMD49    | ac   | [31:0] stuff bits | R1b  | CHANGE_SECURE_AREA | Protected Area Access Command:                                    |
|           |      |                   |      |                    | Change size of Protected Area.                                    |
|           |      |                   |      |                    | Refer to Security Specification<br>Version 2.00 for more details. |
| ACMD51    | adtc | [31:0] stuff bits | R1   | SEND_SCR           | Reads the SD Configuration Register (SCR)                         |

1. Registers mentioned in this table are SD card registers.

#### **NOTE**

- CMD3 differs for MMC and SD cards. For MMC cards, CMD3 is referred to as SET\_RELATIVE\_ADDR and has a response type R1. For SD cards, CMD3 is referred to as SEND\_RELATIVE\_ADDR and has a response type R6, with RCA inside.
- CMD6 differs completely between high-speed MMC cards and high-speed SD cards. Command SWITCH\_FUNC is used for high speed SD cards.
- Command SWITCH is for high-speed MMC cards. The index field can contain any value from 0-255, but only values 0-191 are valid. If the index value is in the 192-255 range, the card does not perform any modification and the status bit EXT\_CSD[SWITCH\_ERROR] is set.

Table 16-36. EXT\_CSD access modes

| Bits | Access name | Operation                                                                               |
|------|-------------|-----------------------------------------------------------------------------------------|
| 00   | Command set | The command set is changed according to the command set field of the argument           |
| 01   | Set bits    | The bits in the pointed byte are set, according to the set bits in the value field.     |
| 10   | Clear bits  | The bits in the pointed byte are cleared, according to the set bits in the value field. |
| 11   | Write byte  | The value field is written into the pointed byte.                                       |

## [other]

• CMD8 differs for MMC and SD cards. For SD cards, CMD8 is referred to as SEND\_IF\_COND. For MMC cards, CMD8 is referred to as SEND\_EXT\_CSD.

## 16.6.6 Software restrictions

When polling read or write, once the software begins a buffer read or write, it must access exactly the number of times as set in the watermark level register, as if a DMA burst occurred.

When the internal DMA is not enabled and a write transaction is in operation, DATPORT (described in Data buffer access port (eSDHC\_DATPORT)) must not be read.

# **Chapter 17 Universal Serial Bus Interface**

This chapter describes the universal serial bus (USB) interface of the device.

## 17.1 Introduction

This chapter describes the universal serial bus (USB) interface of the device.

The USB interface implements many industry standards. However, it is beyond the scope of this document to document the intricacies of these standards. Instead, it is left to the reader to refer to the governing specifications.

The following documents are available from the USB Implementers Forum web page at http://www.usb.org/developers/docs/.

• Universal Serial Bus Revision 2.0 Specification

The following documents are available from the Intel USB Specifications web page at http://www.intel.com/technology/usb/spec.htm.

• Enhanced Host Controller Interface (EHCI) Specification for Universal Serial Bus, Revision 1.0

The following documents are available from the ULPI web page at http://www.ulpi.org.

- UTMI+ Specification, Revision 1.0
- UTMI+ Low Pin Interface (ULPI) Specification, Revision 1.0

The device implements a dual-role (DR) USB module. This module may be connected to an external port. Collectively the module and external port are called the USB interface. The USB interface is shown in the figure below.



Figure 17-1. USB interface block diagram

#### **17.1.1 Overview**

The USB DR module is a USB 2.0-compliant serial interface engine for implementing a USB interface.

The registers and data structures for the module are based on the *Enhanced Host Controller Interface Specification for Universal Serial Bus* (EHCI) from Intel Corporation. The DR module can act as a device or host controller.

The DR module supports the required signaling for and UTMI+ low pin interface (ULPI) transceivers (PHYs). The , and the PHY interfacing to the ULPI is an external PHY.

The module contains a chaining DMA (direct memory access) engine that reduces the interrupt load on the application processor and reduces the total system bus bandwidth that must be dedicated to servicing the USB interface requirements.

## 17.1.2 Features

The USB DR module includes the following features:

- Complies with USB specification rev 2.0
- Supports operation as a standalone USB host controller
  - Supports enhanced host controller interface (EHCI)
- Supports high-speed (480 Mbps), full-speed (12 Mbps), and low-speed (1.5 Mbps) operation. Low speed is only supported in host mode.
- Supports external PHY with ULPI (UTMI+ low pin interface)
- Supports operation as a standalone USB device

- Supports one upstream facing port
- Supports six bidirectional USB endpoints
- Host and device support

## 17.1.3 Modes of operation

The USB DR module has two basic operating modes: host and device.

#### **NOTE**

Only high-speed and full-speed operations are supported in device mode.

# 17.2 USB external signals

This section contains detailed descriptions of all the USB controller signals.

### 17.2.1 ULPI interface

The ULPI (UTMI+ low pin interface) is a reduced pin-count (12 signals) extension of the UTMI+ specification.

Pin count is reduced by converting relatively static signals to register bits, and providing a bidirectional, generic data bus that carries USB and register data. This interface minimizes pin count requirements for external PHYs. The table below describes the signals for the ULPI interface.

Table 17-1. ULPI signal descriptions

| Signal                                                                                                                                                                                                                                                                                                                                             | I/O |                                                                                                                                                                  | Description                                                                          |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| USB_DIR  I Direction. USB_DIR controls the direction of the data bus. When the PHY has data to transf USB port, it drives USB_DIR high to take ownership of the bus. When the PHY has no data transfer it drives USB_DIR low and monitors the bus for link activity. The PHY pulls USB_DI whenever the interface cannot accept data from the link. |     | drives USB_DIR high to take ownership of the bus. When the PHY has no data to ves USB_DIR low and monitors the bus for link activity. The PHY pulls USB_DIR high |                                                                                      |  |  |
|                                                                                                                                                                                                                                                                                                                                                    |     | State<br>Meaning                                                                                                                                                 | Asserted-PHY has data to transfer to the link.  Negated-PHY has no data to transfer. |  |  |
|                                                                                                                                                                                                                                                                                                                                                    |     | Timing                                                                                                                                                           | Synchronous to PHY_CLK.                                                              |  |  |

Table 17-1. ULPI signal descriptions (continued)

| Signal                 | I/O |                            | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------|-----|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USB_NXT                | I   | PHY, USB_1<br>places the n | the PHY asserts USB_NXT to throttle the data. When USB port is sending data to the NXT indicates when the current byte has been accepted by the PHY. The USB port ext byte on the data bus in the following clock cycle. When the PHY is sending data to SB_NXT indicates when a new byte is available for USB port to consume.                                                                             |
|                        |     | State                      | Asserted-PHY is ready to transfer byte.                                                                                                                                                                                                                                                                                                                                                                     |
|                        |     | Meaning                    | Negated-PHY is not ready.                                                                                                                                                                                                                                                                                                                                                                                   |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |
| USB_STP                | 0   | Stop. USB_S                | STP indicates the end of a transfer on the bus.                                                                                                                                                                                                                                                                                                                                                             |
| Meaning or or for both |     |                            | Asserted-USB asserts this signal for 1 clock cycle to stop the data stream currently on the bus. If USB port is sending data to the PHY, USB_STP indicates the last byte of data was previously on the bus. If the PHY is sending data to USB port, USB_STP forces the PHY to end its transfer, negate USB_DIR and relinquish control of the data bus to the USB port.  Negated-Indicates normal operation. |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |
| USB_PWRFAULT           | ı   |                            | USB _PWRFAULT indicates whether a power fault occurred on the USB port Vbus.                                                                                                                                                                                                                                                                                                                                |
| OSD_I WIII AOLI        |     | State<br>Meaning           | Asserted-Indicates that a Vbus fault occurred. Applications that support power switching must shut down Vbus power.                                                                                                                                                                                                                                                                                         |
|                        |     |                            | Negated-Indicates normal operation.                                                                                                                                                                                                                                                                                                                                                                         |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |
| USB_PCTL0              | 0   | Port control               | D. USB_PCTL0 controls the port status indicator LED 0 when in host mode.                                                                                                                                                                                                                                                                                                                                    |
|                        |     | State                      | Asserted-LED on.                                                                                                                                                                                                                                                                                                                                                                                            |
|                        |     | Meaning                    | Negated-LED off.                                                                                                                                                                                                                                                                                                                                                                                            |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |
| USB_PCTL1              | 0   | Port control               | 1. USB_PCTL1 controls the port status indicator LED 1 when in host mode.                                                                                                                                                                                                                                                                                                                                    |
|                        |     | State                      | Asserted-LED on.                                                                                                                                                                                                                                                                                                                                                                                            |
|                        |     | Meaning                    | Negated-LED off.                                                                                                                                                                                                                                                                                                                                                                                            |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |
| USB_D[7:0]             | I/O |                            | SB_D $n$ is bit $n$ of the 8-bit (USBDR_TXDRXD7-USBDR_TXDRXD0), uni-directional and to carry USB register, and interrupt data between the PHY and the USB controller.                                                                                                                                                                                                                                       |
|                        |     | State                      | Asserted-Data bit <i>n</i> is 1.                                                                                                                                                                                                                                                                                                                                                                            |
|                        |     | Meaning                    | Negated-Data bit <i>n</i> is 0.                                                                                                                                                                                                                                                                                                                                                                             |
|                        |     | Timing                     | Synchronous to PHY_CLK.                                                                                                                                                                                                                                                                                                                                                                                     |

## 17.2.2 PHY clocks

The USB\_CLK input provides the clocking signal for the ULPI PHY interface .

The clock is 60 MHz. Detailed clock specifications are given in the appropriate hardware specifications document.

#### NOTE

A write to registers in the USB controller memory map may cause the system to hang if PORTSC[PHCD]=0 when no USB PHY clock is applied.

# 17.3 USB memory map/register definition

This section provides the memory map and detailed descriptions of all USB interface registers.

The following sections provide details about the registers in the USB memory map.

#### NOTE

Memory may be viewed from either a big-endian or little-endian byte ordering perspective depending on the processor configuration. In big-endian mode, the most-significant byte of word 0 is located at address 0 and the least-significant byte of word 0 is located at address 3. In little-endian mode, the least-significant byte of word 0 is located at address 0 and the most-significant byte of word 0 is located at address 3. Within registers, bits are numbered within a word starting with bit 31 as the most-significant bit. By convention USB registers use little-endian byte ordering. In the USB DR module, these are the registers from offsets 0x00 to 0x1FF. The registers associated with the internal system interface (0x400 and above) use big-endian byte ordering.

#### **USB** memory map

| Offset<br>address<br>(hex) | Register name                                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_2000                     | Identification register (USB_ID)                            | 32                 | R      | C340_0005h  | 17.3.1/1269      |
| 2_2100                     | Capability register length (USB_CAPLENGTH)                  | 8                  | R      | 40h         | 17.3.2/1270      |
| 2_2102                     | Host controller interface version number (USB_HCIVERSION)   | 16                 | R      | 0100h       | 17.3.3/1271      |
| 2_2104                     | Host controller structural parameters (USB_HCSPARAMS)       | 32                 | R      | 1101_0000h  | 17.3.4/1271      |
| 2_2108                     | Host controller capability parameters (USB_HCCPARAMS)       | 32                 | R      | 0000_0006h  | 17.3.5/1273      |
| 2_2120                     | Device controller interface version number (USB_DCIVERSION) | 16                 | R      | 0001h       | 17.3.6/1275      |

## **USB** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                       | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------------------|--------------------|--------|-------------|------------------|
| 2_2124                     | Device controller capability parameters (USB_DCCPARAMS)             | 32                 | R      | 0000_0186h  | 17.3.7/1276      |
| 2_2140                     | USB command (USB_USBCMD)                                            | 32                 | R/W    | See section | 17.3.8/1276      |
| 2_2144                     | USB status (USB_USBSTS)                                             | 32                 | R/W    | 0000_0000h  | 17.3.9/1281      |
| 2_2148                     | USB interrupt enable (USB_USBINTR)                                  | 32                 | R/W    | 0000_0000h  | 17.3.10/<br>1285 |
| 2_214C                     | USB frame index (USB_FRINDEX)                                       | 32                 | R/W    | 0000_0000h  | 17.3.11/<br>1287 |
| 2_2154                     | Periodic frame list base address [host mode] (USB_PERIODICLISTBASE) | 32                 | R/W    | 0000_0000h  | 17.3.12/<br>1288 |
| 2_2154                     | USB device address [device mode] (USB_DEVICEADDR)                   | 32                 | R/W    | 0000_0000h  | 17.3.13/<br>1289 |
| 2_2158                     | Next asynchronous list addr [host mode] (USB_ASYNCLISTADDR)         | 32                 | R/W    | 0000_0000h  | 17.3.14/<br>1289 |
| 2_2158                     | Address at endpoint list [device mode] (USB_ENDPOINTLISTADDR)       | 32                 | R/W    | 0000_0000h  | 17.3.15/<br>1290 |
| 2_2160                     | Master interface data burst size (USB_BURSTSIZE)                    | 32                 | R/W    | 0000_1010h  | 17.3.16/<br>1290 |
| 2_2164                     | Transmit FIFO tuning controls (USB_TXFILLTUNING)                    | 32                 | R/W    | 0002_0000h  | 17.3.17/<br>1291 |
| 2_2170                     | ULPI register access (USB_ULPI_VIEWPORT)                            | 32                 | R/W    | 0000_0008h  | 17.3.18/<br>1293 |
| 2_2180                     | Configured flag register (USB_CONFIGFLAG)                           | 32                 | R      | 0000_0001h  | 17.3.19/<br>1295 |
| 2_2184                     | Port status/control (USB_PORTSC)                                    | 32                 | R/W    | 9C00_0000h  | 17.3.20/<br>1296 |
| 2_21A8                     | USB device mode (USB_USBMODE)                                       | 32                 | R/W    | 0000_0000h  | 17.3.21/<br>1303 |
| 2_21AC                     | Endpoint setup status (USB_ENDPTSETUPSTAT)                          | 32                 | w1c    | 0000_0000h  | 17.3.22/<br>1304 |
| 2_21B0                     | Endpoint initialization (USB_ENDPOINTPRIME)                         | 32                 | R/W    | 0000_0000h  | 17.3.23/<br>1305 |
| 2_21B4                     | Endpoint flush (USB_ENDPTFLUSH)                                     | 32                 | R/W    | 0000_0000h  | 17.3.24/<br>1306 |
| 2_21B8                     | Endpoint status (USB_ENDPTSTATUS)                                   | 32                 | R      | 0000_0000h  | 17.3.25/<br>1306 |
| 2_21BC                     | Endpoint complete (USB_ENDPTCOMPLETE)                               | 32                 | w1c    | 0000_0000h  | 17.3.26/<br>1307 |
| 2_21C0                     | Endpoint control 0 (USB_ENDPTCTRL0)                                 | 32                 | R/W    | 0080_0080h  | 17.3.27/<br>1309 |
| 2_21C4                     | Endpoint control n (USB_ENDPTCTRL1)                                 | 32                 | R/W    | 0000_0000h  | 17.3.28/<br>1311 |
| 2_21C8                     | Endpoint control n (USB_ENDPTCTRL2)                                 | 32                 | R/W    | 0000_0000h  | 17.3.28/<br>1311 |

### **USB** memory map (continued)

| Offset address (hex) | Register name                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------|--------------------|--------|-------------|------------------|
| 2_21CC               | Endpoint control n (USB_ENDPTCTRL3)      | 32                 | R/W    | 0000_0000h  | 17.3.28/<br>1311 |
| 2_21D0               | Endpoint control n (USB_ENDPTCTRL4)      | 32                 | R/W    | 0000_0000h  | 17.3.28/<br>1311 |
| 2_21D4               | Endpoint control n (USB_ENDPTCTRL5)      | 32                 | R/W    | 0000_0000h  | 17.3.28/<br>1311 |
| 2_2400               | Snoop n (USB_SNOOP1)                     | 32                 | R/W    | 0000_0000h  | 17.3.29/<br>1313 |
| 2_2404               | Snoop n (USB_SNOOP2)                     | 32                 | R/W    | 0000_0000h  | 17.3.29/<br>1313 |
| 2_2408               | Age count threshold (USB_AGE_CNT_THRESH) | 32                 | R/W    | 0000_0000h  | 17.3.30/<br>1314 |
| 2_240C               | Priority control (USB_PRI_CTRL)          | 32                 | R/W    | 0000_0000h  | 17.3.31/<br>1316 |
| 2_2410               | System interface control (USB_SI_CTRL)   | 32                 | R/W    | 0000_0000h  | 17.3.32/<br>1317 |
| 2_2500               | Control (USB_CONTROL)                    | 32                 | R/W    | 0000_0000h  | 17.3.33/<br>1318 |

# 17.3.1 Identification register (USB\_ID)

The identification registers are used to declare the slave interface presence and include a table of the hardware configuration parameters. These registers are not defined by the EHCI specification.

The ID register provides a simple way to determine if the USB DR module is provided in the system. The ID register identifies the USB DR and its revision.

Address: 2 2000h base + 0h offset = 2 2000h



#### **USB\_ID** field descriptions

| Field             | Description                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------|
| 31–29<br>-        | This field is reserved. Reserved                                                                  |
| 28–25<br>VERSION  | Identifies the version of the module.                                                             |
| 24–21<br>REVISION | Identifies the revision number of the module.                                                     |
| 20–16<br>TAG      | Identifies the tag of the USB core.                                                               |
| 15–14<br>-        | This field is reserved. Reserved                                                                  |
| 13–8<br>NID       | Ones complement version of ID bit.                                                                |
| 7–6<br>-          | This field is reserved. Reserved                                                                  |
| 5–0<br>ID         | Configuration number. This number is set to 0x05 and indicates that the peripheral is the USB_DR. |

# 17.3.2 Capability register length (USB\_CAPLENGTH)

The capability registers specify the software limits, restrictions, and capabilities of the host/device controller implementation. Most of these registers are defined by the EHCI specification. Registers that are not defined by the EHCI specification are noted in their descriptions.

CAPLENGTH is used as an offset to add to the register base address to find the beginning of the operational register space, that is, the location of the USBCMD register.





#### **USB\_CAPLENGTH** field descriptions

| Field | Description                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------|
|       | Indicate which offset to add to the register base address at the beginning of the Operational Register. Value is 0x40. |

# 17.3.3 Host controller interface version number (USB\_HCIVERSION)

HCIVERSION contains a BCD encoding of the EHCI revision number supported by this host controller. The most-significant byte of the register represents a major revision and the least-significant byte is the minor revision.





**USB\_HCIVERSION** field descriptions

| Field            | Description                                                   |
|------------------|---------------------------------------------------------------|
| 15–0<br>HCIVERSI | EHCI revision number. Value is 0x0100 indicating version 1.0. |

# 17.3.4 Host controller structural parameters (USB\_HCSPARAMS)

HCSPARAMS contains structural parameters such as the number of downstream ports

Address: 2\_2000h base + 104h offset = 2\_2104h



#### USB memory map/register definition

## **USB\_HCSPARAMS** field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                               |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                      |
| 27–24<br>N_TT  | Number of transaction translators. This is a non-EHCI field. This field indicates the number of embedded transaction translators associated the module. See Embedded transaction translator function.                                                                                                     |
| 23–20<br>N_PTT | Ports per transaction translator. This is a non-EHCl field. The number of ports assigned to each transaction translator. This is equal to N_PORTS.                                                                                                                                                        |
| 19–17<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                      |
| 16<br>PI       | Port indicators. Indicates whether the ports support port indicator control.  1 The port status and control registers include a R/W field for controlling the state of the port indicator.                                                                                                                |
| 15–12<br>N_CC  | Number of companion controllers associated with the DR controller. Always 0.                                                                                                                                                                                                                              |
| 11–8<br>N_PCC  | Number ports per CC. This field indicates the number of ports supported per internal companion controller. Always 0.                                                                                                                                                                                      |
| 7–5<br>-       | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                      |
| 4<br>PPC       | Power port control. Indicates whether the host controller supports port power control.  ULPI Mode:  0 USBDR will write 0 for DRVVBUS bit of OTG Control register in PHY.  1 USBDR will write 1 for DRVVBUS bit of OTG Control register in PHY.  The OTG cntrol register is defined in ULPI specification. |
| 3-0<br>N_PORTS | Number of ports. Number of physical downstream ports implemented for host applications. The value of this field determines how many port registers are addressable in the operational register.                                                                                                           |

# 17.3.5 Host controller capability parameters (USB\_HCCPARAMS)

HCCPARAMS identifies multiple mode control (time-base bit functionality) addressing capability.





#### USB memory map/register definition



## **USB\_HCCPARAMS** field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>-   | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15–8<br>EECP | EHCI extended capabilities pointer. Indicates the existence of a capabilities list. A value of 0x00 indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 0x40 or greater if implemented to maintain the consistency of the PCI header defined for this class of device.                                                                                                                         |
|              | This field is always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7–4<br>IST   | Isochronous scheduling threshold. Indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule. When bit 7 is zero, the value of the least significant 3 bits indicates the number of microframes a host controller can hold a set of isochronous data structures (one or more) before flushing the state. When bit 7 is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.  This field is always 0. |
| 3 -          | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2<br>ASP     | Asynchronous schedule park capability. Indicates whether the USB DR module supports the park feature for high-speed queue heads in the asynchronous schedule. The feature can be disabled or enabled and set to a specific level by using the asynchronous schedule park mode enable and asynchronous schedule park mode count fields in the USBCMD register.                                                                                                                                                                                     |

### **USB\_HCCPARAMS** field descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                                                                                                               |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | This field is always 1 (park feature supported).                                                                                                                                                                                                                                                                                                          |
| 1<br>PFL | Programmable frame list flag. Indicates whether system software can specify and use a frame list length less that 1024 elements. Frame list size is configured via the USBCMD register frame list size field. The frame list must always be aligned on a 4-K page boundary. This requirement ensures that the frame list is always physically contiguous. |
|          | This field is always 1.                                                                                                                                                                                                                                                                                                                                   |
| 0<br>ADC | 64-bit addressing capability. Always 0; 64-bit addressing is not supported.                                                                                                                                                                                                                                                                               |
|          | 0 Data structures use 32-bit address memory pointers                                                                                                                                                                                                                                                                                                      |

# 17.3.6 Device controller interface version number (USB\_DCIVERSION)

This register is not defined in the EHCI specification. DCIVERSION is a two-byte register containing a BCD encoding of the device controller interface. The most-significant byte of the register represents a major revision and the least-significant byte is the minor revision.





#### **USB\_DCIVERSION** field descriptions

| Field              | Description                       |
|--------------------|-----------------------------------|
| 15-0<br>DCIVERSION | Device interface revision number. |

0

Reset

0

0

0

0

#### 17.3.7 **Device controller capability parameters** (USB\_DCCPARAMS)

This register is not defined in the EHCI specification. This register describes the overall host/device capability of the DR module.



### **USB\_DCCPARAMS** field descriptions

0

0

| Field      | Description                                                                                                                                             |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–9<br>-  | This field is reserved. Reserved, should be cleared.                                                                                                    |
| 8<br>HC    | Host capable. Always 1, indicating the USB DR controller can operate as an EHCI compatible USB 2.0 host                                                 |
| 7<br>DC    | Device capable. Always 1, indicating the USB DR controller can operate as an USB 2.0 device.  1 Device capability.  0 No device capability (host only). |
| 6–5<br>-   | This field is reserved. Reserved, should be cleared.                                                                                                    |
| 4–0<br>DEN | Device endpoint number. Indicates the number of endpoints built into the device controller. Always 0x 6.                                                |

#### 17.3.8 **USB command (USB USBCMD)**

The operational registers are comprised of dynamic control or status registers that may be read-only, read/write, or read/write-1-to-clear. The following sections define the operational registers.

The module executes the command indicated in this register.

Address: 2\_2000h base + 140h offset = 2\_2140h



# **USB\_USBCMD** field descriptions

| Field        | Description                                                                                                                                                                                                                                                              |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>-   | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                     |
| 23–16<br>ITC | Interrupt threshold control. The system software uses this field to set the maximum rate at which the USB DR module issues interrupts. ITC contains the maximum interrupt interval measured in microframes. Valid values are shown below.  0x00 Immediate (no threshold) |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## **USB\_USBCMD** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0x01 1 microframe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|             | 0x02 2 microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             | 0x04 4 microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             | 0x08 8microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|             | 0x10 16 microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | 0x20 32 microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | 0x40 40 microframes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15<br>FS2   | See bits 3-2 below. This is a non-EHCl bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 14<br>ATDTW | Add dTD TripWire. This is a non-EHCl bit. Used as a semaphore when a dTD is added to an active (primed) endpoint. This bit is set and cleared by software. This bit shall also be cleared by hardware when its state machine is in hazard region where adding a dTD to a primed endpoint may go unrecognized. More information on the use of this bit is described in Device operational model.                                                                                                                   |
| 13<br>SUTW  | Setup tripwire. This is a non-EHCI bit. Used as a semaphore when the 8 bytes of setup data read extracted from a QH by the DCD. If the setup lockout mode is off (See USB device mode (USB_USBMODE)) then there exists a hazard when new setup data arrives and the DCD is copying setup from the QH for a previous setup packet. This bit is set and cleared by software and will be cleared by hardware when a hazard exists. More information on the use of this bit is described in Device operational model. |
| 12<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11<br>ASPE  | Asynchronous schedule park mode enable. Software uses this bit to enable or disable park mode.  0 Disabled 1 Enabled                                                                                                                                                                                                                                                                                                                                                                                              |
| 10<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9–8<br>ASP  | Asynchronous schedule park mode count. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the Asynchronous schedule before continuing traversal of the Asynchronous schedule. Valid values are 0x1H to 0x3H. Software must not write a zero to this field when ASPE is set as this results in undefined behavior.                                                                                                             |
| 7<br>LR     | Light host/device controller reset (OPTIONAL). Not implemented. Always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6<br>IAA    | Interrupt on async advance doorbell. Used as a doorbell by software to tell the USB DR controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.                                                                                                                                                                                                                                                                                |
|             | When the controller has evicted all appropriate cached schedule states, it sets USBSTS[AAI]. If USBINTR[AAE] is set, the host controller asserts an interrupt at the next interrupt threshold.                                                                                                                                                                                                                                                                                                                    |
|             | The controller clears this bit after it has set USBSTS[AAI]. Software should not set this bit when the asynchronous schedule is inactive. Doing so yields undefined results.                                                                                                                                                                                                                                                                                                                                      |
|             | This bit is only used in host mode. Setting this bit when the USB DR module is in device mode is selected results in undefined results.                                                                                                                                                                                                                                                                                                                                                                           |
| 5<br>ASE    | Asynchronous schedule enable. Controls whether the controller skips processing the asynchronous schedule. Only used in host mode.                                                                                                                                                                                                                                                                                                                                                                                 |
|             | 0 Do not process the asynchronous schedule                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## **USB\_USBCMD** field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>PSE  | Periodic schedule enable. Controls whether the controller skips processing the periodic schedule. Only used in host mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | <ul> <li>0 Do not process the periodic schedule.</li> <li>1 Use the PERIODICLISTBASE register to access the periodic schedule.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3–2<br>FS | Frame list size. Together with bit 15 these bits make the FS[2:0] field. This field is read/write only if programmable frame list flag in the HCCPARAMS registers is set to 1. This field specifies the size of the frame list that controls which bits in FRINDEX should be used for the frame list current index. Only used in host mode. Note that values below 256 elements are not defined in the EHCI specification.                                                                                                                                                                                                                                          |
|           | 000 1024 elements (4096 bytes)<br>001 512 elements (2048 bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 010 256 elements (1024 bytes) 011 128 elements (512 bytes) 100 64 elements (256 bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 101 32 elements (128 bytes) 110 16 elements (64 bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 111 8 elements (32 bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1<br>RST  | Controller reset. Software uses this bit to reset the controller. This bit is cleared by the controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.  • When software sets this bit, the host controller resets its internal pipelines, timers, counters, state machines, and so on to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports. Software should not set this bit when USBSTS[HCH] is a zero. Attempting to reset an actively running host controller results in undefined behavior. |
|           | When software sets this bit, the USB DR controller resets its internal pipelines, timers, counters, state machines, and so on to their initial value. Any transaction currently in progress on USB is immediately terminated. Writing a one to this bit when the device is in attached state is not recommended, because the effect on an attached host is undefined. In order to ensure that the device is not in attached state before initiating a controller reset, all primed endpoints should be flushed and the USBCMD[RS] bit should be set to 0.                                                                                                           |
|           | NOTE: Once set, this bit is HIGH for 63 clock cycles of system clock and then it transitions back to 0. Softwarelets the previous reset complete before setting this bit again. On setting this bit, the USBDR also resets the PHY. Software ensures that PHY also comes out reset beforesetting this bit again.                                                                                                                                                                                                                                                                                                                                                    |
| 0         | Run/Stop.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RS        | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | <ul> <li>When this bit is set, the controller proceeds with the execution of the schedule. The controller continues execution as long as this bit is set. When this bit is set to 0, the host controller completes the current transaction on the USB and then halts. The USBSTS[HCH] bit indicates when the USB DR controller has finished the transaction and has entered the stopped state. Software should not write a one to this field unless the controller is in the halted state (that is, USBSTS[HCH] is a one).</li> </ul>                                                                                                                               |
|           | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | <ul> <li>Setting this bit causes the USB DR controller to enable a pull-up on D+ and initiate an attach event. This control bit is not directly connected to the pull-up enable, as the pull-up is disabled upon transitioning into high-speed mode. Software should use this bit to prevent an attach event before the controller has been properly initialized. Clearing this bit causes a detach event.</li> </ul>                                                                                                                                                                                                                                               |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### USB memory map/register definition

## **USB\_USBCMD** field descriptions (continued)

| Field | Description |
|-------|-------------|
|       | 0 Stop      |
|       | 1 Run       |

# 17.3.9 USB status (USB\_USBSTS)

The USB status register indicates various states of the USB DR module and any pending interrupts. This register does not indicate status resulting from a transaction on the serial bus. Software clears certain bits in this register by writing a 1 to them (indicated by a w1c in the bit's W cell).



#### USB memory map/register definition



## **USB\_USBSTS** field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>- | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                 |
| 15<br>AS   | Asynchronous schedule status. Reports the current real status of the asynchronous schedule. The USB DR controller is not required to immediately disable or enable the asynchronous schedule when software transitions USBCMD[ASE]. When this bit and USBCMD[ASE] have the same value, the asynchronous schedule is either enabled (1) or disabled (0). Only used in host mode.  O Disabled  Enabled |
| 14<br>PS   | Periodic schedule status. Reports the current real status of the periodic schedule. The USB DR controller is not required to immediately disable or enable the periodic schedule when software transitions USBCMD[PSE]. When this bit and USBCMD[PSE] have the same value, the periodic schedule is either enabled (1) or disabled (0). Only used in host mode.  O Disabled  Enabled                 |
| 13<br>RCL  | Reclamation. Used to detect an empty asynchronous schedule. Only used by the host mode.  0 Non-empty asynchronous schedule 1 Empty asynchronous schedule                                                                                                                                                                                                                                             |

## **USB\_USBSTS** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12<br>HCH   | HC halted. This bit is a zero whenever USBCMD[RS] is a one. The USB DR controller sets this bit to one after it has stopped executing because of USBCMD[RS] being cleared, either by software or by the host controller hardware (for example, internal error). Only used in host mode.  0 Running                                                                                                                                                                                                                                       |
|             | 1 Halted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10<br>ULPII | ULPI interrupt. An event completion to the viewport register sets this bit. If the ULPI enables the USBINTR[ULPIE] to be set, the USB interrupt (UI) occurs.                                                                                                                                                                                                                                                                                                                                                                             |
| 9 -         | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8<br>SLI    | DC Suspend. This is a non-EHCI bit. When a device controller enters a suspend state from an active state, this bit is set. The device controller clears the bit upon exiting from a suspend state. Only used by the device controller.  O Active                                                                                                                                                                                                                                                                                         |
|             | 1 Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7<br>SRI    | <ul> <li>Host mode:</li> <li>This is a non-EHCl status bit. In host mode, this bit is set every 125 μs, provided the PHY clock is present and running (for example, the port is NOT suspended), and can be used by the host controller driver as a time base.</li> </ul>                                                                                                                                                                                                                                                                 |
|             | <ul> <li>SOF received. When the USB DR controller detects a Start Of (Micro)Frame, this bit is set. When a SOF is extremely late, the DR controller automatically sets this bit to indicate that an SOF was expected. Therefore, this bit is set roughly every 1 msec in device FS mode and every 125 µs in HS mode and is synchronized to the actual SOF that is received. Because the controller is initialized to FS before connect, this bit is set at an interval of 1 msec during the prelude to the connect and chirp.</li> </ul> |
|             | Software writes a 1 to this bit to clear it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6<br>URI    | USB reset received. This is a non-EHCI bit. When the USB DR controller detects a USB reset and enters the default state, this bit is set. Software can write a 1 to this bit to clear the USB reset received status bit. Only used by the device mode.  O No reset received Reset received                                                                                                                                                                                                                                               |
| 5<br>AAI    | Interrupt on async advance. System software can force the controller to issue an interrupt the next time the USB DR controller advances the asynchronous schedule by writing a one to USBCMD[IAA]. This status bit indicates the assertion of that interrupt source. Only used by the host mode.                                                                                                                                                                                                                                         |
|             | No async advance interrupt     Async advance interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4<br>SEI    | System error. This bit is set whenever an error is detected on the system bus. If USBINTR[SEE] is set, an interrupt is generated. The interrupt and status bits remain asserted until cleared by writing a 1 to this bit. Additionally, when in host mode, USBCMD[RS] is cleared, effectively disabling the USB DR controller. For the USB DR controller in device mode, an interrupt is generated, but no other action is taken.                                                                                                        |
|             | <ul><li>0 Normal operation</li><li>1 Error</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## **USB\_USBSTS** field descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>FRI | Frame list rollover. The controller sets this bit to a one when the frame list index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size (as programmed in USBCMD[FS]) is 1024, FRINDEX rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the USB DR controller sets this bit to a one every time FRINDEX [12] toggles. Only used by the host mode.                                                                    |
| 2        | Port change detect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCI      | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | <ul> <li>The controller sets this bit when a connect status occurs on any port, a port enable/disable change<br/>occurs, an over current change occurs, or PORTSC[FPR] is set as the result of a J-K transition on<br/>the suspended port.</li> </ul>                                                                                                                                                                                                                                                                                                   |
|          | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | <ul> <li>The USB DR controller sets this bit when it enters the full or high-speed operational state. When the port controller exits the full or high-speed operation states due to reset or suspend events, the notification mechanisms are USBSTS[URI] and USBSTS[SLI], respectively.</li> </ul>                                                                                                                                                                                                                                                      |
|          | The controller also sets this bit when the VBUS de-asserts (occurs when the host disables port power or the device has been disconnected from the bus). This bit is not EHCl compatible.                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>UEI | USB error interrupt (USBERRINT). When completion of a USB transaction results in an error condition, this bit is set by the controller. This bit is set along with the UI, if the TD on which the error interrupt occurred also had its interrupt on complete (IOC) bit set. See Section 4.15.1 in EHCI for a complete list of host error interrupt conditions. Also see Table 17-104 in this chapter for more information on device error matrix. For the USB DR controller in device mode, only resume signaling is detected, all others are ignored. |
|          | 0 No error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | 1 Error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| O<br>UI  | USB interrupt (USBINT). This bit is set by the controller when the cause of an interrupt is a completion of a USB transaction where the transfer descriptor (TD) has an interrupt on complete (IOC) bit set. This bit is also set by the controller when a short packet is detected. A short packet is when the actual number of bytes received was less than the expected number of bytes.                                                                                                                                                             |

## 17.3.10 USB interrupt enable (USB\_USBINTR)

The interrupts to software are enabled with the USB interrupt enable register. An interrupt is generated when a bit is set and the corresponding interrupt is active. The USB status register (USBSTS) still shows interrupt sources even if they are disabled by the USBINTR register, allowing polling of interrupt events by the software.



**USB\_USBINTR** field descriptions

| Field       | Description                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–11<br>-  | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                    |
| 10<br>ULPIE | ULPI interrupt enable. An event completion to the viewport register sets the USBSTS[ULPII]. If the ULPI enables ULPIE bit to be set, then the USBINT (USBSTS[UI]) occurs.  0 Disable 1 Enable                                           |
| 9 -         | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                    |
| 8<br>SLE    | Sleep enable. This is a non-EHCl bit. When this bit is a one, and USBSTS[SLI] transitions, the USB DR controller issues an interrupt. The interrupt is acknowledged by software writing a one to USBSTS[SLI]. Only used in device mode. |

#### USB memory map/register definition

# **USB\_USBINTR** field descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0 Disable 1 Enable                                                                                                                                                                                                                                                   |
| 7<br>SRE | SOF received enable. This is a non-EHCl bit. When this bit is a one, and USBSTS[SRI] is a one, the controller issues an interrupt. The interrupt is acknowledged by software clearing USBSTS[SRI].  0 Disable 1 Enable                                               |
| 6<br>URE | USB reset enable. This is a non-EHCl bit. When this bit is a one, and USBSTS[URI] is a one, the device controller issues an interrupt. The interrupt is acknowledged by software clearing USBSTS[URI] bit. Only used in device mode.  0 Disable 1 Enable             |
| 5<br>AAE | Interrupt on async advance enable. When this bit is a one, and USBSTS[AAI] is a one, the controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing USBSTS[AAI]. Only used in host mode.  0 Disable 1 Enable |
| 4<br>SEE | System error enable. When this bit is a one, and USBSTS[SEI] is a one, the controller issues an interrupt. The interrupt is acknowledged by software clearing USBSTS[SEI].  0 Disable 1 Enable                                                                       |
| 3<br>FRE | Frame list rollover enable. When this bit is a one, and USBSTS[FRI] is a one, the controller issues an interrupt. The interrupt is acknowledged by software clearing USBSTS[FRI]. Only used by the host mode.  0 Disable 1 Enable                                    |
| 2<br>PCE | Port change detect enable. When this bit is a one, and USBSTS[PCI] is a one, the controller issues an interrupt. The interrupt is acknowledged by software clearing USBSTS[PCI].  0 Disable 1 Enable                                                                 |
| 1<br>UEE | USB error interrupt enable. When this bit is a one, and USBSTS[UEI] is a one, the controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing USBSTS[UEI].  0 Disable 1 Enable                                |
| 0<br>UE  | USB interrupt enable. When this bit is a one, and USBSTS[UI] is a one, the DR controller issues an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing USBSTS[UI].  0 Disable 1 Enable                                     |

## 17.3.11 USB frame index (USB\_FRINDEX)

In host mode, the frame index register is used by the controller to index the periodic frame list. The register updates every 125 microseconds (once each microframe). Bits N-3 are used to select a particular entry in the periodic frame list during periodic schedule execution. The number of bits used for the index depends on the size of the frame list as set by system software in USBCMD[FS].

This register must be written as a DWord. Byte writes produce-undefined results. This register cannot be written unless the USB DR controller is in the Halted state as indicated by the USBSTS[HCH]. A write to this register while USBCMD[RS] is set produces undefined results. Writes to this register also affect the SOF value.

In device mode, this register is read-only and the USB DR controller updates the FRINDEX[13-3] register from the frame number indicated by the SOF marker. Whenever a SOF is received by the USB bus, FRINDEX[13-3] is checked against the SOF marker. If FRINDEX[13-3] is different from the SOF marker, FRINDEX[13-3] is set to the SOF value and FRINDEX[2-0] is cleared (that is, SOF for 1 msec frame). If FRINDEX[13-3] is equal to the SOF value, FRINDEX[2-0] is incremented (that is, SOF for 125-µsec microframe).

The table below illustrates values of N based on the value of the Frame List Size in the USBCMD register, when used in host mode.

USBCMD[FS] Frame List Size **FRINDEX N value** 000 1024 elements (4096 bytes) 12 11 001 512 elements (2048 bytes) 010 256 elements (1024 bytes) 10 9 011 128 elements (512 bytes) 8 100 64 elements (256 bytes) 7 101 32 elements (128 bytes) 110 16 elements (64 bytes) 6 111 8 elements (32 bytes) 5

Table 17-13. FRINDEX N Values

Address: 2\_2000h base + 14Ch offset = 2\_214Ch



#### **USB\_FRINDEX** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–14<br>-      | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                         |
| 13-0<br>FRINDEX | Frame index. The value in this register increments at the end of each time frame (for example, microframe). Bits N-3 are used for the Frame List current index. This means that each location of the frame list is accessed 8 times (frames or microframes) before moving to the next index. |
|                 | In device mode, the value is the current frame number of the last frame transmitted. It is not used as an index.                                                                                                                                                                             |
|                 | In either mode, bits 2-0 indicate the current microframe.                                                                                                                                                                                                                                    |

# 17.3.12 Periodic frame list base address [host mode] (USB\_PERIODICLISTBASE)

This register contains the beginning address of the Periodic frame list in the system memory. The host controller driver loads this register prior to starting the schedule execution by the controller. The memory structure referenced by this physical memory pointer is assumed to be 4-Kbyte aligned. The contents of this register are combined with the frame index register (FRINDEX) to enable the controller to step through the Periodic Frame List in sequence.

Note that this register is shared between the host and device mode functions. In host mode, it is the PERIODICLISTBASE register; in device mode, it is the DEVICEADDR register. See USB device address [device mode] (USB\_DEVICEADDR), for more information.

Address: 2\_2000h base + 154h offset = 2\_2154h



## **USB\_PERIODICLISTBASE** field descriptions

| Field            | Description                                                                            |
|------------------|----------------------------------------------------------------------------------------|
| 31–12<br>PERBASE | Base address. Correspond to memory address signal [31:12]. Only used in the host mode. |
| 11–0<br>-        | This field is reserved. Reserved, should be cleared.                                   |

## 17.3.13 USB device address [device mode] (USB\_DEVICEADDR)

The device address register is not defined in the EHCI specification. In device mode, the upper seven bits of this register represent the device address. After any controller reset or a USB reset, the device address is set to the default address (0). The default address will match all incoming addresses. Software shall reprogram the address after receiving a SET\_ADDRESS descriptor.

Note that this register is shared between the host and device mode functions. In device mode, it is the DEVICEADDR register; in host mode, it is the PERIODICLISTBASE register. See Periodic frame list base address [host mode] (USB PERIODICLISTBASE), for more information.





#### **USB\_DEVICEADDR** field descriptions

| Field           | Description                                                       |
|-----------------|-------------------------------------------------------------------|
| 31–25<br>USBADR | Device address. This field corresponds to the USB device address. |
| 24–0            | This field is reserved. Reserved, should be cleared.              |

# 17.3.14 Next asynchronous list addr [host mode] (USB\_ASYNCLISTADDR)

This 32-bit register contains the address of the next asynchronous queue head to be executed by the host. Bits 4-0 of this register cannot be modified by the system software and always return zeros when read.

Note that this register is shared between the host and device mode functions. In host mode, it is the ASYNCLISTADDR register; in device mode, it is the ENDPOINTLISTADDR register. See Address at endpoint list [device mode] (USB\_ENDPOINTLISTADDR), for more information.

Address: 2\_2000h base + 158h offset = 2\_2158h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **USB\_ASYNCLISTADDR** field descriptions

| Field | Description                                                                                                                                                        |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Link pointer low (LPL). These bits correspond to memory address signals [31:5]. This field may only reference a queue head (QH). Only used by the host controller. |
| 4–0   | This field is reserved. Reserved, should be cleared.                                                                                                               |

# 17.3.15 Address at endpoint list [device mode] (USB\_ENDPOINTLISTADDR)

The endpoint list address register is not defined in the EHCI specification. In device mode, this register contains the address of the top of the endpoint list in system memory. Bits 10-0 of this register cannot be modified by the system software and always return zeros when read. The memory structure referenced by this physical memory pointer is assumed to be 64-bytes. The queue head is actually a 48-byte structure, but must be aligned on 64-byte boundary. However, the ENDPOINTLISTADDR[EPBASE] has a granularity of 2 Kbytes, so in practice the queue head should be 2-Kbyte aligned.

Note that this register is shared between the host and device mode functions. In device mode, it is the ENDPOINTLISTADDR register; in host mode, it is the ASYNCLISTADDR register. See Next asynchronous list addr [host mode] (USB\_ASYNCLISTADDR), for more information.

Address: 2\_2000h base + 158h offset = 2\_2158h



## **USB\_ENDPOINTLISTADDR** field descriptions

| Field           | Description                                                     |
|-----------------|-----------------------------------------------------------------|
| 31–11<br>EPBASE | Endpoint list address. Address of the top of the endpoint list. |
| 10–0            | This field is reserved. Reserved, should be cleared.            |

# 17.3.16 Master interface data burst size (USB\_BURSTSIZE)

The master interface data burst size register is not defined in the EHCI specification. This register is used to control and dynamically change the burst size used during data movement on the initiator (master) interface.

Note that BURSTSIZE[TXPBURST] and BURSTSIZE[RXPBURST] are effectively write-only fields. The actual value written in the register is used correctly for the burst length, but the fields always return 10h.

Address: 2\_2000h base + 160h offset = 2\_2160h



#### **USB BURSTSIZE field descriptions**

| Field            | Description                                                                                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>-       | This field is reserved. Reserved, should be cleared.                                                                                                                                         |
| 15–8<br>TXPBURST | Programable TX burst length. This register represents the maximum length of a burst in 32-bit words while moving data from system memory to the USB bus. Must not be set to greater that 16. |
| 7–0<br>RXPBURST  | Programable RX burst length. This register represents the maximum length of a burst in 32-bit words while moving data from the USB bus to system memory. Must not be set to greater than 16. |

# 17.3.17 Transmit FIFO tuning controls (USB\_TXFILLTUNING)

The transmit FIFO tuning controls register is not defined in the EHCI specification. This register is used to control and dynamically change the burst size used during data movement on device DMA transfers. It is only used in host mode.

The fields in this register control performance tuning associated with how the USB DR module posts data to the TX latency FIFO before moving the data onto the USB bus. The specific areas of performance include how much data to post into the FIFO and an estimate for how long that operation should take in the target system.

#### **Definitions:**

 $T_0$  = Standard packet overhead

 $T_1$  = Time to send data payload

 $T_s$  = Total Packet Flight Time (send-only) packet ( $Ts = T_0 + T_1$ )

 $T_{\rm ff}$  = Time to fetch packet into TX FIFO up to specified level.

 $T_p$  = Total Packet Time (fetch and send) packet ( $T_p = T_{ff} + T_s$ )

Upon discovery of a transmit (OUT/SETUP) packet in the data structures, host controller checks to ensure T  $_p$  remains before the end of the [micro]frame. If so it proceeds to prefill the TX FIFO. If at any time during the pre-fill operation the time remaining the [micro]frame is < T  $_s$  then the packet attempt ceases and the packet is tried at a later time.

#### USB memory map/register definition

Although this is not an error condition and the module eventually recovers, a mark is made in the scheduler health counter to note the occurrence of a back-off event. When a back-off event is detected, the partial packet fetched may need to be discarded from the latency buffer to make room for periodic traffic that will begin after the next SOF. Too many back-off events can waste bandwidth and power on the system bus and thus should be minimized (not necessarily eliminated). Back-offs can be minimized with use of the TSCHHEALTH (T <sub>ff</sub>) parameter described below.

Address: 2\_2000h base + 164h offset = 2\_2164h



#### **USB\_TXFILLTUNING** field descriptions

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–22<br>-           | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21–16<br>TXFIFOTHRES | FIFO burst threshold. Control the number of data bursts that are posted to the TX latency FIFO in host mode before the packet begins on to the bus. The minimum value is 2 and this value should be a low as possible to maximize USB performance. A higher value can be used in systems with unpredictable latency and/or insufficient bandwidth where the FIFO may underrun because the data transferred from the latency FIFO to USB occurs before it can be replenished from system memory.                                                                                                                                                |
|                      | This value is ignored if USBMODE[SDIS] (stream disable bit) is set. When USBMODE[SDIS] is set, the host controller behaves as if TXFIFOTHRES is set to the maximum value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15–13<br>-           | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12–8<br>TXSCHHEALTH  | Scheduler health counter. Increment when the host controller fails to fill the TX latency FIFO to the level programmed by TXFIFOTHRES before running out of time to send the packet before the next Start-Of-Frame.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                      | This health counter measures the number of times this occurs to provide feedback to selecting a proper TXSCHOH. Writing to this register clears the counter and this counter stops counting after reaching the maximum of 31.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7-0<br>TXSCHOH       | Scheduler overhead. These bits add an additional fixed offset to the schedule time estimator described above as T ff. As an approximation, the value chosen for this register should limit the number of back-off events captured in the TXSCHHEALTH to less than 10 per second in a highly utilized bus. Choosing a value that is too high for this register is not desired as it can needlessly reduce USB utilization.  • The time unit represented in this register is 1.267µs when a device is connected in high-speed mode.  • The time unit represented in this register is 6.333µs when a device is connected in low-/full-speed mode. |
|                      | For most applications, TXSCHOH can be set to 4 or less. A good value to begin with is: TXFIFOTHRES x (BURSTSIZE x 4 bytes-per-word) ÷ (40 x TimeUnit), always rounded to the next higher integer. TimeUnit is either 1.267 or 6.333 as noted earlier in this description. For example, if TXFIFOTHRES is 5 and BURSTSIZE is 8, then set TXSCHOH to 5x(8x4)÷(40x1.267)=4 for a high-speed link. If this value of TXSCHOH results in a TXSCHHEALTH count of 0 per second, try lowering the value by 1 if optimizing performance is desired. If TXSCHHEALTH exceeds 10 per second, try raising the value by 1.                                    |
|                      | If streaming mode is disabled via the USBMODE register, treat TXFIFOTHRES as the maximum value for purposes of the TXSCHOH calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## 17.3.18 ULPI register access (USB\_ULPI\_VIEWPORT)

The ULPI register access provides indirect access to the ULPI PHY register set. Although the controller modules perform access to the ULPI PHY register set, there may be extraordinary circumstances where software may need direct access. Be advised that writes to the ULPI through the ULPI viewport can substantially harm standard USB operations. Currently no usage model has been defined where software should need to execute writes directly to the ULPI. Note that executing read operations though the ULPI viewport should have no harmful side effects to standard USB operations. Also note that if the ULPI interface is not enabled, this register will always read zeros.

There are two operations that can be performed with the ULPI viewport, wakeup and read /write operations. The wakeup operation is used to put the ULPI interface into normal operation mode and re-enable the clock if necessary. A wakeup operation is required before accessing the registers when the ULPI interface is operating in low power mode, serial mode, or carkit mode. The ULPI state can be determined by reading the sync state bit (ULPISS). If this bit is set, then the ULPI interface is running in normal operation mode and can accept read/write operations. If the ULPISS is cleared, then read/write operations will not be able execute. Undefined behavior results if a read or write operation is performed when ULPISS is cleared. To execute a wakeup operation, write all 32-bits of the ULPI Viewport where ULPIPORT is constructed appropriately and the ULPIWU bit is set and the ULPIRUN bit is cleared. Poll the ULPI Viewport until ULPIWU is cleared for the operation to complete.

To execute a read or write operation, write all 32-bits of the ULPI Viewport where ULPIDATWR, ULPIADDR, ULPIPORT, ULPIRW are constructed appropriately and the ULPIRUN bit is set. Poll the ULPI Viewport until ULPIRUN is cleared for the operation to complete. For read operations, ULPIDATRD is valid once ULPIRUN is cleared.

The polling method above can be replaced with interrupts using the ULPI interrupt defined in the USBSTS and USBINTR registers. When a wakeup or read/write operation completes, the ULPI interrupt is set.

#### NOTE

Read or write to the ULPI PHY extended register set (address > 3Fh) is not supported.

#### USB memory map/register definition

Address: 2\_2000h base + 170h offset = 2\_2170h



## **USB\_ULPI\_VIEWPORT** field descriptions

| Field             | Description                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ULPIWU      | ULPI Wake Up. Writing 1 to this bit begins the wakeup operation. This bit automatically transitions to 0 after the wakeup is complete. Once this bit is set, it can not be cleared by software.            |
|                   | NOTE: The driver must never execute a wakeup and a read/write operation at the same time.                                                                                                                  |
| 30<br>ULPIRUN     | ULPI Run. Writing 1 to this bit begins a read/write operation. This bit automatically transitions to 0 after the read/write is complete. Once this bit is set, it can not be cleared by software.          |
|                   | NOTE: The driver must never execute a wakeup and a read/write operation at the same time.                                                                                                                  |
| 29<br>ULPIRW      | This bit selects between running a read or write operation to the ULPI.  O Read                                                                                                                            |
|                   | 1 Write                                                                                                                                                                                                    |
| 28                | This field is reserved. Reserved, should be cleared.                                                                                                                                                       |
| 27<br>ULPISS      | This bit represents the state of the ULPI interface. Before reading this bit, the ULPIPORT field should be set accordingly if used with the multi-port host. Otherwise, this field should always remain 0. |
|                   | O Any other state (that is, carkit, serial, low power).                                                                                                                                                    |
|                   | 1 Normal Sync State.                                                                                                                                                                                       |
| 26–24<br>ULPIPORT | For wakeup or read/write operations this value selects the port number to which the ULPI PHY is attached. Valid values are 0 and 1.                                                                        |
| 23–16<br>ULPIADDR | When a read or write operation is commanded, the address of the operation is written to this field.                                                                                                        |
| 15–8<br>ULPIDATRD | After a read operation completes, the result is placed in this field.                                                                                                                                      |
| 7–0<br>ULPIDTWR   | When a write operation is commanded, the data to be sent is written to this field.                                                                                                                         |

# 17.3.19 Configured flag register (USB\_CONFIGFLAG)

This EHCI register is not used in this implementation. A read from this register returns a constant of a  $0x0000\_0001$  to indicate that all port routings default to this host controller.

Address: 2\_2000h base + 180h offset = 2\_2180h



P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### **USB\_CONFIGFLAG** field descriptions

| Field     | Description                                                                  |
|-----------|------------------------------------------------------------------------------|
| 31–1<br>- | This field is reserved. Reserved.                                            |
| 0<br>CF   | Configure flag. Always 1. Indicating all port routings default to this host. |

## 17.3.20 Port status/control (USB\_PORTSC)

The port status and control (PORTSC) register is only reset when power is initially applied or in response to a controller reset. The initial conditions of a port are:

- No device connected
- Port disabled

If the port has port power control, this state remains until software applies power to the port by setting port power to one.

In device mode, the USB DR controller does not support power control. Port control in device mode is only used for status port reset, suspend, and current connect status. It is also used to initiate test mode or force signaling and allows software to put the PHY into low power suspend mode and disable the PHY clock.







**USB\_PORTSC** field descriptions

| Field | Description                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------|
| 31–30 | Port transceiver select. This register bit is used to control which parallel transceiver interface is selected. |
| PTS   | This bit is not defined in the EHCI specification.                                                              |
|       | 00 Reserved                                                                                                     |
|       | 01 Reserved, should be cleared                                                                                  |
|       | 10 ULPI parallel interface                                                                                      |
|       | 11 Reserved                                                                                                     |
| 29    | This field is reserved.                                                                                         |
| -     | Reserved, should be cleared                                                                                     |
| 28    | This field is reserved.                                                                                         |
| -     | Reserved, should be cleared                                                                                     |
| 27–26 | Port speed. This read-only register field indicates the speed at which the port is operating.                   |
| PSPD  | This bit is not defined in the EHCI specification.                                                              |
|       | 00 Full-speed                                                                                                   |
|       | 01 Low-speed                                                                                                    |
|       | 10 High-speed                                                                                                   |
|       | 11 Undefined                                                                                                    |

| Field        | Description                                                                                                                                                                                                                                                                       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>-      | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                               |
| 24<br>PFSC   | Port force full-speed connect. Used to disable the chirp sequence that allows the port to identify itself as a HS port. This is useful for testing FS configurations with a HS host, hub or device.                                                                               |
|              | This bit is not defined in the EHCI specification.                                                                                                                                                                                                                                |
|              | This bit is for debugging purposes.                                                                                                                                                                                                                                               |
|              | <ul><li>0 Allow the port to identify itself as high speed.</li><li>1 Force the port to only connect at full speed.</li></ul>                                                                                                                                                      |
| 23<br>PHCD   | PHY low power suspend. This bit is not defined in the EHCI specification.                                                                                                                                                                                                         |
| PHOD         | Host mode:                                                                                                                                                                                                                                                                        |
|              | <ul> <li>The PHY can be put into low power suspend - when the downstream device has been put into<br/>suspend mode or when no downstream device is connected. Low power suspend is completely<br/>under the control of software.</li> </ul>                                       |
|              | Device mode:                                                                                                                                                                                                                                                                      |
|              | <ul> <li>The PHY can be put into low power suspend - when the device is not running (USBCMD[RS] = 0b) or suspend signaling is detected on the USB. Low power suspend is cleared automatically when the resume signaling has been detected or when forcing port resume.</li> </ul> |
|              | Reading this bit indicates the status of the PHY.                                                                                                                                                                                                                                 |
|              | NOTE: If there is no clock connected to the USB _CLK signals, PHCD must be set and the following registers should not be written: DEVICE_ADDR/PERIODICLISTBASE, PORTSC, ENDPTCTRL0, ENDPTCTRL1, ENDPTCTRL2, ENDPTCTRL3, ENDPTCTRL4, ENDPTCTRL5.                                   |
|              | 0 Normal PHY operation.                                                                                                                                                                                                                                                           |
|              | 1 Signal the PHY to enter low power suspend mode                                                                                                                                                                                                                                  |
| 22<br>WKOC   | Wake on over-current enable. Writing this bit to a one enables the port to be sensitive to over-current conditions as wake-up events.                                                                                                                                             |
|              | This field is zero if Port Power (PP) is zero.                                                                                                                                                                                                                                    |
|              | This bit is used only in Host mode , and is used by an external power control circuit .                                                                                                                                                                                           |
| 21<br>WKDS   | Wake on disconnect enable. Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.                                                                                                                                                    |
|              | This field is zero if Port Power(PP) is zero or in device mode.                                                                                                                                                                                                                   |
|              | This bit is used only in Host mode, and is used by an external power control circuit.                                                                                                                                                                                             |
| 20<br>WKCN   | Wake on connect enable. Writing this bit to a one enables the port to be sensitive to device connects as wake-up events.                                                                                                                                                          |
|              | This field is zero if Port Power(PP) is zero or in device mode.                                                                                                                                                                                                                   |
|              | This bit is used only in Host mode, and is used by an external power control circuit.                                                                                                                                                                                             |
| 19–16<br>PTC | Port test control. Any other value than zero indicates that the port is operating in test mode. Note that for K_STATE test mode (Test_K), a controller reset (Host mode) or power cycle (Device mode) is required after the test completes.                                       |
|              | Refer to Chapter 7 of the USB Specification Revision 2.0 [3] for details on each test mode.                                                                                                                                                                                       |
|              | 0000 Not Enabled<br>0001 J_STATE                                                                                                                                                                                                                                                  |

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0010 K_STATE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | 0011 SEQ_NAK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | 0100 Packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|              | 0101 FORCE_ENABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|              | 0110-1111 Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15–14<br>PIC | Port indicator control. Control the link indicator signals. These signals are valid for host mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 110          | This field is output from the controller for use by an external LED driving circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | NOTE: PORTSC[15] is mapped to PCTL1 and PORTSC[14] is mapped to PCTL0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | 00 Off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | 01 Amber                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | 10 Green                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | 11 Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13<br>PO     | Port owner. Unconditionally goes to a 0 when the configured bit in the CONFIGFLAG register makes a 0 to 1 transition. This bit unconditionally goes to 1 whenever the Configured bit is zero. System software uses this field to release ownership of the port to a selected module (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that an internal companion controller owns and controls the port. |
|              | Port owner hand-off is not implemented in this design, therefore this bit is always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12<br>PP     | Port power. Represents the current setting of the switch (0=off, 1=on). When power is not available on a port (that is, PP equals a 0), the port is non-functional and will not report attaches, detaches, and so on.                                                                                                                                                                                                                                                                                                                    |
|              | The operation of Port Power bit is independent of USBDR mode (host or device / USBMODE[CM]).                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | ULPI mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | 0 USBDR writes 0 for DRVVBUS bit of OTGControl register in PHY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              | 1 USBDR writes 1 for DRVVBUS bit of OTGControl register in PHY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              | The OTG Control register is defined in ULPI specification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11–10<br>LS  | Line status. Reflect the current logical levels of the USB D+ (bit 11) and D- (bit 10) signal lines. The use of line status by the host controller driver is not necessary (unlike EHCI), because the connection of FS and LS is managed by hardware.                                                                                                                                                                                                                                                                                    |
|              | 00 SE0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | 10 J-state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | 01 K-state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | 11 Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9 -          | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8            | Port reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PR           | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | <ul> <li>When software writes a one to this bit the bus-reset sequence as defined in the USB Specification<br/>Revision 2.0 is started. This bit will automatically change to zero after the reset sequence is<br/>complete. This behavior is different from EHCI where the host controller driver is required to set this<br/>bit to a zero after the reset duration is timed in the driver.</li> </ul>                                                                                                                                 |
|              | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _         | This bit is a read only status bit. Device reset from the USB bus is also indicated in the USBSTS register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | This field is zero if Port Power(PP) is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | 1 Port is in reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | 0 Port is not in reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7<br>SUSP | Suspend.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0001      | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | The port enabled bit (PE) and suspend (SUSP) bit define the port states as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | 0x Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | 10 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 11 Suspend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | <ul> <li>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspended and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.</li> <li>The module unconditionally sets this bit to zero when software clears the FPR bit. A write of zero this bit is ignored by the host controller. If host software sets this bit to a one when the port is not enabled (that is, port enabled bit is a zero) the results are undefined.</li> <li>This field is zero if Port Power (PP) is zero in host mode.</li> </ul> |
|           | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | 1 Port in suspend state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 0 Port not in suspend state. Default.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | In device mode this bit is a read-only status bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6         | Force port resume. This bit is not-EHCl compatible.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FPR       | 1 Resume detected/driven on port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 0 No resume (K-state) detected/driven on port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | <ul> <li>Software sets this bit to one to drive resume signaling. The controller sets this bit to one if a J-to-k transition is detected while the port is in the Suspend state. When this bit transitions to a one a J-K transition is detected, USBSTS[PCI] (port change detect) is also set. This bit will automatically change to zero after the resume sequence is complete. This behavior is different from EHCI when the host controller driver is required to set this bit to a zero after the resume duration is timed in the driver.</li> <li>Note that when the controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driver on the port as long as this bit remains a one. This bit will remain a one until the port has switched</li> </ul>     |
|           | the high-speed idle. Writing a zero has no affect because the port controller will time the resume operation and clear this bit when the port control state switches to HS or FS idle.  • This field is zero if Port Power (PP) is zero in host mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|           | <ul> <li>After the device has been in Suspend State for 5 msec or more, software must set this bit to one t<br/>drive resume signaling before clearing. The USB DR controller will set this bit to one if a J-to-K</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | <b>—</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | transition is detected while the port is in the Suspend state. The bit is cleared when the device returns to normal operation. Also, when this bit transitions to a one because a J-to-K transition detected, USBSTS[PCI] is also set.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5<br>OCC | Over-current change. This bit gets set when there is a change to over-current active. Software clears this bit by writing a one to this bit position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | The user can provide over-current detection to the USB _PWRFAULT signal for this condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | This bit must always be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | Over current detect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|          | 0 No over current.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4<br>OCA | Over-current active. This bit will automatically transition from one to zero when the over current condition is removed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | The user can provide over-current detection to the USB _PWRFAULT signal for this condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | This bit must always be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | 1 Port currently in over-current condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 0 Port not in over-current condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3<br>PEC | Port enable/disable change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PEC      | For the root hub, this bit gets set only when a port is disabled due to disconnect on the port or due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification). Software clears this by writing a one to it.                                                                                                                                                                                                                                                                                                                                                                                 |
|          | In device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          | The device port is always enabled. (This bit is zero.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          | This field is zero if Port Power(PP) is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          | 1 Port disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | 0 No change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2<br>PE  | Port enabled/disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ''-      | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | <ul> <li>Ports can only be enabled by the controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. Ports can be disabled by either a fault condition (disconnect event or other fault condition) or by the host software. Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host and bus events.</li> <li>When the port is disabled, (0) downstream propagation of data is blocked except for reset.</li> <li>This field is zero if Port Power(PP) is zero in host mode.</li> </ul> |
|          | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | The device port is always enabled. (This bit is one.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | Connect change status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CSC   | Host mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | <ul> <li>This bit indicates a change has occurred in the port's Current Connect Status. the controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware is 'setting' an already-set bit (that is, the bit will remain set). Software clears this bit by writing a one to it.</li> </ul> |
|       | 1 Connect Status has changed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | 0 No change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | This field is zero if Port Power(PP) is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | Device mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | This bit is undefined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0     | Current Connect Status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ccs   | Host Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 1 Device is present on port                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 0 No device is present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change bit to be set.                                                                                                                                                                                                                                                                                                                                                      |
|       | This field is zero if Port Power(PP) is zero in host mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | Device Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | 1 Attached                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 0 Not attached                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | A one indicates that the device successfully attached and is operating in either high speed or full speed as indicated by the PSPD bits in this register. A zero indicates that the device did not attach successfully or was forcibly disconnected by the software writing a zero to USBCMD[RS] (run bit). It does not state the device being disconnected or suspended.                                                                                                                                 |
|       | A value of zero also occurs if vbus de-asserts either when the host disables port power or the device has been disconnected from the bus.                                                                                                                                                                                                                                                                                                                                                                 |

# 17.3.21 USB device mode (USB\_USBMODE)

The USB mode register is not defined in the EHCI specification. This register controls the operating mode of the module.



**USB\_USBMODE** field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–5      | This field is reserved.                                                                                                                                                                                                                                                                                                                                                                              |
| -         | Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>SDIS | Stream disable  In host mode, setting this bit ensures that overruns/underruns of the latency FIFO are eliminated for low bandwidth systems where the RX and TX buffers are sufficient to contain the entire packet. Enabling stream disable also has the effect of ensuring the TX latency is filled to capacity or a complete packet is stored in FIFO before the packet is launched onto the USB. |
|           | Note that time duration to pre-fill the FIFO becomes significant when stream disable is active. See Transmit FIFO tuning controls (USB_TXFILLTUNING) to characterize the adjustments needed for the scheduler when using this feature.                                                                                                                                                               |
|           | Also note that in systems with high system bus utilization, setting this bit will ensure no overruns or underruns during operation, at the expense of link utilization. For those who desire optimal link performance, SDIS can be left clear, and the rules used under the description of the TXFILLTUNING register to limit underruns/overruns.                                                    |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### **USB\_USBMODE** field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | In device mode, setting this bit disables double priming on both RX and TX for low bandwidth systems.  This mode ensures that when the RX and TX buffers are sufficient to contain an entire packet that the standard double buffering scheme is disabled to prevent overruns/underruns in bandwidth limited systems. |
|           | Note that in high-speed mode, all packets received are responded to with a NYET handshake when stream disable is active.                                                                                                                                                                                              |
|           | 1 Active.                                                                                                                                                                                                                                                                                                             |
|           | 0 Inactive.                                                                                                                                                                                                                                                                                                           |
| 3<br>SLOM | Setup lockout mode. In device mode, this bit controls behavior of the setup lock mechanism. See Control endpoint operation model .                                                                                                                                                                                    |
|           | <ol> <li>Setup lockouts off. DCD requires use of setup data buffer tripwire in USBCMD (SUTW).</li> <li>Setup lockouts on</li> </ol>                                                                                                                                                                                   |
| 2 -       | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                  |
| 1–0       | Controller mode                                                                                                                                                                                                                                                                                                       |
| CM        | This register can only be written once after reset. If it is necessary to switch modes, software must reset the controller by writing to USBCMD[RST] before reprogramming this register.                                                                                                                              |
|           | Defaults to the idle state and needs to be initialized to the desired operating mode after reset.                                                                                                                                                                                                                     |
|           | 00 Idle (default ).                                                                                                                                                                                                                                                                                                   |
|           | 01 Reserved, should be cleared.                                                                                                                                                                                                                                                                                       |
|           | 10 Device controller .                                                                                                                                                                                                                                                                                                |
|           | 11 Host controller .                                                                                                                                                                                                                                                                                                  |

### 17.3.22 Endpoint setup status (USB\_ENDPTSETUPSTAT)

The endpoint setup status register is not defined in the EHCI specification. This register contains the endpoint setup status. It is only used in device mode.

Address: 2\_2000h base + 1ACh offset = 2\_21ACh



#### **USB\_ENDPTSETUPSTAT** field descriptions

| Field | Description                  |
|-------|------------------------------|
| 31–6  | This field is reserved.      |
| -     | Reserved, should be cleared. |

### **USB\_ENDPTSETUPSTAT** field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENDPTSETUPSTAT | Setup endpoint status. For every setup transaction that is received, a corresponding bit in this register is set. Software must clear or acknowledge the setup transfer by writing a one to a respective bit after it has read the setup data from queue head. The response to a setup packet as in the order of operations and total response time is crucial to limit bus time outs while the setup lockout mechanism is engaged.  This register is only used in device mode. |

# 17.3.23 Endpoint initialization (USB\_ENDPOINTPRIME)

The endpoint initialization register is not defined in the EHCI specification. This register is used to initialize endpoints. It is only used in device mode.

Address: 2\_2000h base + 1B0h offset = 2\_21B0h



#### **USB\_ENDPOINTPRIME** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–22<br>-    | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 21–16<br>PETB | Prime endpoint transmit buffer. For each endpoint a corresponding bit is used to request that a buffer prepared for a transmit operation in order to respond to a USB IN/INTERRUPT transaction. Software should write a one to the corresponding bit when posting a new transfer descriptor to an endpoint. Hardware will automatically use this bit to begin parsing for a new transfer descriptor from the queue head and prepare a transmit buffer. Hardware will clear this bit when the associated endpoint(s) is (are) successfully primed. PETB[5] (bit 21 of the register) corresponds to endpoint 5. |
|               | Note that these bits are momentarily set by hardware during hardware re-priming operations when a dTD is retired, and the dQH is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15–6<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5–0<br>PERB   | Prime endpoint receive buffer. For each endpoint, a corresponding bit is used to request a buffer prepare for a receive operation in order to respond to a USB OUT transaction. Software should write a one to the corresponding bit whenever posting a new transfer descriptor to an endpoint. Hardware will automatically use this bit to begin parsing for a new transfer descriptor from the queue head and prepare a receive buffer. Hardware will clear this bit when the associated endpoint(s) is (are) successfully primed. PERB[5] corresponds to endpoint 5.                                       |
|               | Note that these bits are momentarily set by hardware during hardware re-priming operations when a dTD is retired, and the dQH is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 17.3.24 Endpoint flush (USB\_ENDPTFLUSH)

The endpoint flush register is not defined in the EHCI specification. This register is only used in device mode.

Address: 2\_2000h base + 1B4h offset = 2\_21B4h



#### **USB\_ENDPTFLUSH** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–22<br>-    | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                             |
| 21–16<br>FETB | Flush endpoint transmit buffer. Writing a one to a bit(s) in this register will cause the associated endpoint(s) to clear any primed buffers. If a packet is in progress for one of the associated endpoints, then that transfer will continue until completion. Hardware will clear this register after the endpoint flush operation is successful. FETB[5] (bit 21 of the register) corresponds to endpoint 5. |
| 15–6<br>-     | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                             |
| 5–0<br>FERB   | Flush endpoint receive buffer. Writing a one to a bit(s) will cause the associated endpoint(s) to clear any primed buffers. If a packet is in progress for one of the associated endpoints, then that transfer will continue until completion. Hardware will clear this register after the endpoint flush operation is successful. FERB[5] corresponds to endpoint 5.                                            |

# 17.3.25 Endpoint status (USB\_ENDPTSTATUS)

The endpoint status register is not defined in the EHCI specification. This register is only used in device mode.

Address: 2\_2000h base + 1B8h offset = 2\_21B8h



### **USB\_ENDPTSTATUS** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31–22<br>-    | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 21–16<br>ETBR | Endpoint transmit buffer ready. One bit for each endpoint indicates status of the respective endpoint buffer. This bit is set by the hardware as a response to receiving a command from a corresponding bit in the ENDPTPRIME register. There will always be a delay between setting a bit in the ENDPTPRIME register and endpoint indicating ready. This delay time varies based upon the current USB traffic and the number of bits set in the ENDPTPRIME register. Buffer ready is cleared by USB reset, by the USB DMA system, or through the ENDPTFLUSH register. ETBR[5] (bit 21 of the register) corresponds to endpoint 5. |  |
|               | Note that these bits are momentarily cleared by hardware during hardware endpoint re-priming operations when a dTD is retired, and the dQH is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 15–6<br>-     | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 5-0<br>ERBR   | Endpoint receive buffer ready. One bit for each endpoint indicates status of the respective endpoint buffer. This bit is set by the hardware as a response to receiving a command from a corresponding bit in the ENDPTPRIME register. There will always be a delay between setting a bit in the ENDPTPRIME register and endpoint indicating ready. This delay time varies based upon the current USB traffic and the number of bits set in the ENDPTPRIME register. Buffer ready is cleared by USB reset, by the USB DMA system, or through the ENDPTFLUSH register. ERBR[5] corresponds to endpoint 5.                           |  |
|               | Note that these bits are momentarily cleared by hardware during hardware endpoint re-priming operations when a dTD is retired, and the dQH is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |

# 17.3.26 Endpoint complete (USB\_ENDPTCOMPLETE)

The endpoint complete register is not defined in the EHCI specification. This register is only used in device mode.

Address: 2\_2000h base + 1BCh offset = 2\_21BCh



### **USB\_ENDPTCOMPLETE** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–22<br>-    | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                         |
| 21–16<br>ETCE | Endpoint transmit complete event. Each bit indicates a transmit event (IN/INTERRUPT) occurred and software should read the corresponding endpoint queue to determine the endpoint status. If the corresponding IOC bit is set in the Transfer Descriptor, then this bit is set simultaneously with the USBINT. Writing a one will clear the corresponding bit in this register. ETCE[5] (bit 21 of the register) corresponds to endpoint 5. |

#### USB memory map/register definition

# **USB\_ENDPTCOMPLETE** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15–6<br>-   | is field is reserved. eserved, should be cleared                                                                                                                                                                                                                                                                                                                                                               |  |
| 5–0<br>ERCE | Endpoint receive complete event. Each bit indicates a received event (OUT/SETUP) occurred and software should read the corresponding endpoint queue to determine the transfer status. If the corresponding IOC bit is set in the Transfer Descriptor, then this bit is set simultaneously with the USBINT. Writing a one will clear the corresponding bit in this register. ERCE[5] corresponds to endpoint 5. |  |

# 17.3.27 Endpoint control 0 (USB\_ENDPTCTRL0)

Endpoint control register 0 is not defined in the EHCI specification. Every device will implement endpoint 0 as a control endpoint.



# **USB\_ENDPTCTRL0** field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                             |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31–24<br>-   | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 23<br>TXE    | TX endpoint enable. Endpoint zero is always enabled.  0 Disable 1 Enable                                                                                                                                                                                                                                |  |  |  |
| 22–20        | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 19–18<br>TXT | TX endpoint type. Endpoint zero is always a control endpoint (00).                                                                                                                                                                                                                                      |  |  |  |
| 17 -         | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 16<br>TXS    | TX endpoint stall. Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. It will continue returning STALL until the bit is cleared by software or it will automatically be cleared upon receipt of a new SETUP request.  1 Endpoint stalled 0 Endpoint OK |  |  |  |
| 15–8<br>-    | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 7<br>RXE     | RX endpoint enable. Endpoint zero is always enabled.  0 Disabled 1 Enabled                                                                                                                                                                                                                              |  |  |  |
| 6–4          | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 3–2<br>RXT   | RX endpoint type. Endpoint zero is always a control endpoint (00).                                                                                                                                                                                                                                      |  |  |  |
| 1 -          | This field is reserved. Reserved, should be cleared.                                                                                                                                                                                                                                                    |  |  |  |
| 0<br>RXS     | RX endpoint stall  Software can write a one to this bit to force the endpoint to return a STALL handshake to the host. It will continue returning STALL until the bit is cleared by software or it will automatically be cleared upon receipt of a new SETUP request.  1 Endpoint stalled 0 Endpoint OK |  |  |  |

# 17.3.28 Endpoint control n (USB\_ENDPTCTRLn)

The endpoint control n registers are not defined in the EHCI specification. There is an ENDPTCTRL n register of each endpoint in a device.



USB\_ENDPTCTRLn field descriptions

| Field      | Description                                                                                                                                                                                                                                                             |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31–24<br>- | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                     |  |  |
| 23<br>TXE  | TX endpoint enable  0 Disabled  1 Enabled                                                                                                                                                                                                                               |  |  |
| 22<br>TXR  | TX data toggle reset. Whenever a configuration event is received for this endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device.                                                                           |  |  |
| 21<br>TXI  | TX data toggle inhibit. Used only for test and should always be written as zero. Writing a one to this bit will cause this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet.  0 PID sequencing enabled 1 PID sequencing disabled |  |  |
| 20         | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                     |  |  |

# **USB\_ENDPTCTRL***n* field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19–18     | TX endpoint type                                                                                                                                                                                                                                             |
| TXT       | NOTE: When only one endpoint (RX or TX, but not both) of an endpoint pair is used, the unused endpoint should be configured as a bulk type endpoint.                                                                                                         |
|           | 00 Control                                                                                                                                                                                                                                                   |
|           | 01 Isochronous                                                                                                                                                                                                                                               |
|           | 10 Bulk<br>11 Interrupt                                                                                                                                                                                                                                      |
| 17        | TX endpoint data source. This bit should always be written as 0, which selects the dual port memory/DMA                                                                                                                                                      |
| TXD       | engine as the source.                                                                                                                                                                                                                                        |
| 16<br>TXS | TX endpoint stall. This bit is set automatically upon receipt of a SETUP request if this endpoint is not configured as a control endpoint. It is cleared automatically upon receipt of a SETUP request if this endpoint is configured as a control endpoint. |
|           | Software can write a one to this bit to force the endpoint to return a STALL handshake to the host. It will continue to returning STALL until this bit is either cleared by software or automatically cleared as above.                                      |
|           | Endpoint OK     Endpoint stalled                                                                                                                                                                                                                             |
| 15–8<br>- | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                          |
| 7<br>RXE  | RX endpoint enable                                                                                                                                                                                                                                           |
| NAL .     | <ul><li>0 Disabled</li><li>1 Enabled</li></ul>                                                                                                                                                                                                               |
| 6<br>RXR  | RX data toggle reset. Whenever a configuration event is received for this endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device.                                                                |
| 5<br>RXI  | RX data toggle inhibit. This bit is only used for test and should always be written as zero. Writing a one to this bit will cause this endpoint to ignore the data toggle sequence and always accept data packets regardless of their data PID.              |
|           | 1 PID sequencing enabled                                                                                                                                                                                                                                     |
|           | 0 PID sequencing disabled                                                                                                                                                                                                                                    |
| 4 -       | This field is reserved.  Reserved, should be cleared                                                                                                                                                                                                         |
| 3–2       | RX endpoint type.                                                                                                                                                                                                                                            |
| RXT       | NOTE: When only one endpoint (RX or TX, but not both) of an endpoint pair is used, the unused endpoint should be configured as a bulk type endpoint.                                                                                                         |
|           | 00 Control                                                                                                                                                                                                                                                   |
|           | 01 Isochronous                                                                                                                                                                                                                                               |
|           | 10 Bulk                                                                                                                                                                                                                                                      |
| 1         | 11 Interrupt  RX endpoint data sink. This bit should always be written as 0, which selects the dual port memory/DMA                                                                                                                                          |
| RXD       | engine as the sink. This bit should always be written as 0, which selects the dual port memory/DMA                                                                                                                                                           |
| 0<br>RXS  | RX endpoint stall. This bit is set automatically upon receipt of a SETUP request if this endpoint is not configured as a control endpoint. It is cleared automatically upon receipt a SETUP request if this endpoint is configured as a control endpoint,    |

#### **USB\_ENDPTCTRL***n* field descriptions (continued)

| Field | Description                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Software can write a one to this bit to force the endpoint to return a STALL handshake to the host. It will continue to returning STALL until this bit is either cleared by software or automatically cleared as above, |
|       | 1 Endpoint stalled 0 Endpoint OK                                                                                                                                                                                        |

# 17.3.29 Snoop n (USB\_SNOOP*n*)

The SNOOP1 and SNOOP2 registers are shown below. Note that these registers use bigendian byte ordering and are not defined in the EHCI specification. The SNOOP1 and SNOOP2 registers provide snooping control and address range selection function. Transactions that hit a snooping window will generate cache coherent transactions on the internal CCB bus. When the five lower bits (SNOOP n [27-31]) are equal to 00000, snooping is always disabled on the CCB for all DMA transfers. When SNOOP n [27-31] is 01011 through 11110, the twenty upper bits (SNOOP n [0-19]) provide the starting base address for which transactions are snooped. These twenty bits are compared to the twenty upper bits of the address provided by the DMA block of the USB controller. When a match occurs, the five lower bits are decoded as shown below. This provides a snooping region of 4 Kbytes to 2 Gbytes within each starting base address that is programmed by the core. The SNOOP n [20-26] are not used.





#### USB\_SNOOPn field descriptions

| Field         | Description                                                               |  |
|---------------|---------------------------------------------------------------------------|--|
| 0–19          | The starting base address for which transactions are snooped.             |  |
| Snoop_address |                                                                           |  |
| 20–26         | This field is reserved.                                                   |  |
| -             | Reserved, should be cleared                                               |  |
| 27–31         | Snoop_Enables                                                             |  |
| Snoop_Enables |                                                                           |  |
|               | 0x00 Snooping disabled                                                    |  |
|               | 0x0B 4-Kbyte snoop range starting at the value defined by SNOOP n [0-19]  |  |
|               | 0x0C 8-Kbyte snoop range starting at the value defined by SNOOP n [0-18]  |  |
|               | 0x0D 16-Kbyte snoop range starting at the value defined by SNOOP n [0-17] |  |
|               | 0x0E 32-Kbyte snoop range starting at the value defined by SNOOP n [0-16] |  |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **USB\_SNOOP***n* field descriptions (continued)

| Field |      | Description                                                           |
|-------|------|-----------------------------------------------------------------------|
|       | 0x0F | 64-Kbyte snoop range starting at the value defined by SNOOP n [0-15]  |
|       | 0x10 | 128-Kbyte snoop range starting at the value defined by SNOOP n [0-14] |
|       | 0x11 | 256-Kbyte snoop range starting at the value defined by SNOOP n [0-13] |
|       | 0x12 | 512-Kbyte snoop range starting at the value defined by SNOOP n [0-12] |
|       | 0x13 | 1-Mbyte snoop range starting at the value defined by SNOOP n [0-11]   |
|       | 0x14 | 2-Mbyte snoop range starting at the value defined by SNOOP n [0-10]   |
|       | 0x15 | 4-Mbyte snoop range starting at the value defined by SNOOP n [0-9]    |
|       | 0x16 | 8-Mbyte snoop range starting at the value defined by SNOOP n [0-8]    |
|       | 0x17 | 16-Mbyte snoop range starting at the value defined by SNOOP n [0-7]   |
|       | 0x18 | 32-Mbyte snoop range starting at the value defined by SNOOP n [0-6]   |
|       | 0x19 | 64-M byte snoop range starting at the value defined by SNOOP n [0-5]  |
|       | 0x1A | 128-Mbyte snoop range starting at the value defined by SNOOP n [0-4]  |
|       | 0x1B | 256-Mbyte snoop range starting at the value defined by SNOOP n [0-3]  |
|       | 0x1C | 512-Mbyte snoop range starting at the value defined by SNOOP n [0-2]  |
|       | 0x1D | 1-Gbyte snoop range starting at the value defined by SNOOP n [0-1]    |
|       | 0x1E | 2-Gbyte snoop range starting at the value defined by SNOOP $n$ [0]    |

### 17.3.30 Age count threshold (USB\_AGE\_CNT\_THRESH)

Note that this register uses big-endian byte ordering and is not defined in the EHCI specification. The age count threshold (AGE\_CNT\_THRESH) register provides the aging counter threshold value used to determine the priority state of the USB DR controller's internal system interface. This is used to increase the priority state of the module's system interface from zero to one. The actual priority level on the system bus for each state is defined by the PRI\_CTRL register. The threshold value is in units of *ccb\_clk* cycles. This register should be written during system initialization or during normal system operation when the system bus interface is idle. It can be read at any time.

If the aging counter is less than the AGE\_CNT\_THRESH value, priority state zero is chosen. If the aging counter is greater than or equal to the AGE\_CNT\_THRESH value, priority state one is chosen.

The aging counter begins to count from zero when a bus access is requested. It increments every bus cycle until the bus transaction completes. At the completion of a bus transaction, the counter is synchronously reset to zero. If there are any outstanding bus requests, the aging counter will then begin counting immediately.

The AGE\_CNT\_THRESH is compared against the value of the aging counter during each clock cycle of the current transaction. If AGE\_CNT\_THRESH is equal to zero, priority state one is always chosen. If the aging counter is less than the AGE\_CNT\_THRESH value, priority state zero is selected. If the aging counter is greater than or equal to the AGE\_CNT\_THRESH value, priority state one is selected.

The two priority states of the aging counter function each have corresponding register bits which are programmed by the CPU. Thus, when the aging counter function is at priority state zero, PRI\_CTRL[30-31] are selected and used to drive bus priority levels. When the aging counter function is at priority state one, PRI\_CTRL[28-29] are selected and used to drive the priority.

The setting of AGE\_CNT\_THRESH is highly dependent on both the mix of other controllers operating on the system bus as well as the kind of traffic moving through the USB controller. A recommended approach is first to try leaving the aging mechanism disabled and see if the USB meets performance requirements. If USB performance does not meet application requirements, try the following settings:

- Set PRI\_CTRL[pri\_lvl0] to 0.
- Set PRI\_CTRL[pri\_lvl1] to 3.
- Set AGE\_CNT\_THRESH to 40.

This combination works for a wide variety of applications. If this combination still does not meet application requirements, try lowering AGE\_CNT\_THRESH by 5. On the contrary, the setting 40 may be too conservative for some applications. If USB performance is acceptable at 40, try raising the value in increments of 5. Raising AGE\_CNT\_THRESH benefits the other controllers on the system bus by reducing the frequency that this USB controller raises its priority to the arbiter.

Address: 2 2000h base + 408h offset = 2 2408h



#### **USB\_AGE\_CNT\_THRESH** field descriptions

| Field              | Description                                         |  |
|--------------------|-----------------------------------------------------|--|
| 0–17               | This field is reserved. Reserved, should be cleared |  |
| 18–31<br>Threshold | Aging counter threshold value.                      |  |

### 17.3.31 Priority control (USB\_PRI\_CTRL)

Note that this register uses big-endian byte ordering and is not defined in the EHCI specification. The priority control (PRI\_CTRL) register sets the priority level for each of two priority states. The priority state is determined by the value programmed in the AGE\_CNT\_THRESH register and the number of  $ccb\_clk$  cycles that a particular transaction takes to complete .





### **USB\_PRI\_CTRL** field descriptions

| Field             | Description                                                                                        |  |
|-------------------|----------------------------------------------------------------------------------------------------|--|
| _                 | This field is reserved. Reserved, should be cleared                                                |  |
| 28–29<br>pri_lvl1 | Priority level for priority state 1. The highest priority is 2'h3 and the lowest priority is 2'b0. |  |
| 30–31<br>pri_lvl0 | Priority level for priority state 0. The highest priority is 2'h3 and the lowest priority is 2'b0. |  |

# 17.3.32 System interface control (USB\_SI\_CTRL)

Note that this register uses big-endian byte ordering and is not defined in the EHCI specification. The system interface control register (SI\_CTRL) controls various functions pertaining to the internal system interface.



**USB\_SI\_CTRL** field descriptions

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–26<br>-             | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 27<br>err_disable     | When this bit is set, it causes the controller to ignore system bus errors. If cleared the controller responds according to the values set in USBSTS[SEI] and USBINT[SEE].  0 enable 1 disable                                                                                                                                                                                                                                                                                         |  |  |
| 28–30<br>-            | This field is reserved. Reserved, should be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 31<br>rd_prefetch_val | Selects whether 32 bytes or 64 bytes are fetched during burst read transactions at the system interface. When this input is ZERO 64 bytes are fetched, and when it is ONE 32 bytes are fetched. The setting of rd_prefetch_val must match the setting of the larger of TXPBURST and RXPBURST fields in the BURSTSIZE register. If either of these fields is 64 bytes, then rd_prefetch_val must be left cleared. Otherwise, this value should be set.  0 64-byte fetch 1 32-byte fetch |  |  |

# 17.3.33 Control (USB\_CONTROL)

Note that this register uses big-endian byte ordering and is not defined in the EHCI specification. The USB general purpose (CONTROL) register contains the general-purpose IP control register outputs.



**USB\_CONTROL** field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–14         | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 15<br>-      | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 16–28<br>-   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 29<br>USB_EN | ULPI mode: In safe mode, all USB interface signals are put into input mode or driven inactive, except for SUSPEND_STP, which is driven high. Also, the input signal DIR is forced to appear high to the controller. This prevents any start-up problems that otherwise could occur if the PHY and the controller take significantly different times to complete power-on reset.  1 Normal operation  0 Safe mode |

#### **USB\_CONTROL** field descriptions (continued)

| Field             | Description                                                                                             |
|-------------------|---------------------------------------------------------------------------------------------------------|
| 30<br>-           | This field is reserved. Reserved                                                                        |
| 31<br>ULPI_INT_EN | Used to enable the ULPI low power wakeup interrupt from the PHY when the PHY is in low power mode only. |
|                   | NOTE: PORTSC[PHCD] bit must be set.                                                                     |
|                   | 0 ULPI low power wakeup interrupt disabled                                                              |
|                   | 1 ULPI low power wakeup interrupt enabled                                                               |

# 17.4 Functional description

The USB DR module can be broken down into functional sub-blocks, which are described below.

### 17.4.1 System interface

The system interface block contains all the control and status registers that allow a processor to interface to the USB DR module.

These registers allow the processor to control the configuration of the module, ascertain the capabilities of the module, and control the module's operation. It also has registers to control snoopability and priority of the DMA interface.

### 17.4.2 DMA engine

The module contains a local DMA engine.

The DMA engine interfaces internally to the CCB. It is responsible for moving all of the data to be transferred over the USB between the module and buffers in system memory.

Like the system interface block, the DMA engine block uses a simple synchronous bus signaling protocol that eases connections to a number of different standard buses.

The DMA controller must access both control information and packet data from system memory. The control information is contained in link list-based queue structures. The DMA controller has state machines that are able to parse data structures defined in the EHCI specification. In host mode, the data structures are EHCI compliant and represent queues of transfers to be performed by the host controller, including the split-transaction requests that allow an EHCI controller to direct packets to FS and LS devices. In device

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Host data structures

mode, the data structures are designed to be similar to those in the EHCI specification and are used to allow device responses to be queued for each of the active pipes in the device.

#### 17.4.3 FIFO RAM controller

The FIFO RAM controller is used for context information and to control FIFOs between the protocol engine and the DMA controller.

These FIFOs decouple the system processor/memory bus requests from the extremely tight timing required by USB.

The use of the FIFO buffers differs between host and device mode operation. In host mode, a single data channel is maintained in each direction through the buffer memory. In device mode, multiple FIFO channels are maintained for each of the active endpoints in the system.

In host mode, the USB DR module uses a 512-byte Tx buffer and a 512-byte Rx buffer. Device operation uses a single 512-byte Rx buffer and a 512-byte Tx buffer for each endpoint. The 512-byte buffers allow the module to buffer a complete HS bulk packet.

### 17.4.4 PHY interface

The USB DR module interfaces to any or ULPI-compatible PHY.

The primary function of the port controller block is to isolate the rest of the module from the transceiver, and to move all of the transceiver signaling into the primary clock domain of the module.

This allows the module to run synchronously with the system processor and its associated resources.

Due to pincount limitations the module only supports certain combinations of PHY interfaces and USB functionality. Refer to the table below for more information.

Table 17-43. Supported PHY interfaces

| PHY  | Function    |
|------|-------------|
| ULPI | Host/Device |

### 17.5 Host data structures

This section defines the interface data structures used to communicate control, status, and data between HCD (software) and the Enhanced Host Controller (hardware).

The data structure definitions in this section support a 32-bit memory buffer address space. The interface consists of a periodic schedule, periodic frame list, asynchronous schedule, isochronous transaction descriptors, split-transaction isochronous transfer descriptors, queue heads, and queue element transfer descriptors.

The periodic frame list is the root of all periodic (isochronous and interrupt transfer type) support for the host controller interface. The asynchronous list is the root for all the bulk and control transfer type support. Isochronous data streams are managed using isochronous transaction descriptors. Isochronous split-transaction data streams are managed with split-transaction isochronous transfer descriptors. All interrupt, control, and bulk data streams are managed with queue heads and queue element transfer descriptors. These data structures are optimized to reduce the total memory footprint of the schedule and to reduce (on average) the number of memory accesses needed to execute a USB transaction.

Note that software must ensure that no interface data structure reachable by the EHCI host controller spans a 4K-page boundary.

The data structures defined in this section are (from the host controller's perspective) a mix of read-only and read/writable fields. The host controller must preserve the read-only fields on all data structure writes.

### 17.5.1 Periodic frame list

The figure below shows the organization of the periodic schedule. This schedule is for all periodic transfers (isochronous and interrupt).

The periodic schedule is referenced from the operational registers space using the PERIODICLISTBASE address register and the FRINDEX register. The periodic schedule is based on an array of pointers called the periodic frame list. The PERIODICLISTBASE address register is combined with the FRINDEX register to produce a memory pointer into the frame list. The periodic frame list implements a sliding window of work over time.



Figure 17-42. Periodic schedule organization

The periodic frame list is a 4K-page aligned array of Frame List Link pointers. The length of the frame list is programmable. The programmability of the periodic frame list is exported to system software through the HCCPARAMS register. The length can be selected by system software as one of 8, 16, 32, 64, 128, 256, 512 or 1024 elements. Programming the size (that is, the number of elements) is accomplished by system software writing the appropriate value into Frame List Size field in the USBCMD register.

Frame list link pointers direct the host controller to the first work item in the frame's periodic schedule for the current microframe. The link pointers are aligned on DWord boundaries within the frame list. The table below shows the format for the frame list link pointer.

Table 17-44. Frame list link pointer format

| 31                         |  |  |  |  |  |  |  |     |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------|--|--|--|--|--|--|--|-----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|---|---|---|---|---|
| Frame List Link Pointer 00 |  |  |  |  |  |  |  | Тур | ) | Т |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |   |   |   |   |   |

Frame list link pointers always reference memory objects that are 32-byte aligned. The referenced object may be an isochronous transfer descriptor for high-speed devices, a split-transaction isochronous transfer descriptor (for full-speed isochronous endpoints), or

a queue head (used to support high-, full- and low-speed interrupt). System software should not place non-periodic schedule items into the periodic schedule. The least-significant bits in a frame list pointer are used to key the host controller in as to the type of object the pointer is referencing.

The least-significant bit is the T bit (bit 0). When this bit is set, the host controller never uses the value of the frame list pointer as a physical memory pointer. The Typ field indicates the exact type of data structure being referenced by this pointer. The value encodings for the Typ field are given in the table below.

| Тур | Description                                       |
|-----|---------------------------------------------------|
| 00  | Isochronous transfer descriptor                   |
| 01  | Queue head                                        |
| 10  | Split transaction isochronous transfer descriptor |
| 11  | Frame span traversal node                         |

Table 17-45. Typ field encodings

# 17.5.2 Asynchronous list queue head pointer

The asynchronous transfer list (based at the ASYNCLISTADDR register) is where all the control and bulk transfers are managed.

Host controllers use this list only when it reaches the end of the periodic list, the periodic list is disabled, or the periodic list is empty. The figure below shows the asynchronous schedule organization.



Figure 17-43. Asynchronous schedule organization

The asynchronous list is a simple circular list of queue heads. The ASYNCLISTADDR register is simply a pointer to the next queue head. This implements a pure round-robin service for all queue heads linked into the asynchronous list.

### 17.5.3 Isochronous (high-speed) transfer descriptor (iTD)

The table below shows the format of an isochronous transfer descriptor.

This structure is used only for high-speed isochronous endpoints.

All other transfer types should use queue structures. Isochronous TDs must be aligned on a 32-byte boundary.

3 2 2 2 2 2 2 2 2 2 2 1 1 9 8 7 6 5 3 2 1 offset 0 9 8 7 3 2 8 1 4 3 2 00 Тур 0x00 Next link pointer Status<sup>1</sup> Transaction 0 Length<sup>1</sup> PG<sup>2</sup> Transaction 0 Offset<sup>2</sup> 0x04 ioc Transaction 1 offset<sup>2</sup> Status<sup>1</sup> Transaction 1 length1 ioc PG<sup>2</sup> 0x08 Status<sup>1</sup> PG<sup>2</sup> Transaction 2 length1 Transaction 2 offset<sup>2</sup> 0x0C ioc Status<sup>1</sup> Transaction 3 length<sup>1</sup> PG<sup>2</sup> Transaction 3 offset<sup>2</sup> 0x10 ioc Status<sup>1</sup> Transaction 4 length<sup>1</sup> PG<sup>2</sup> Transaction 4 offset<sup>2</sup> 0x14 ioc Status<sup>1</sup> Transaction 5 length1 ioc PG<sup>2</sup> Transaction 5 offset<sup>2</sup> 0x18 Status<sup>1</sup> Transaction 6 length<sup>1</sup> ioc PG<sup>2</sup> Transaction 6 offset<sup>2</sup> 0x1C Status<sup>1</sup> Transaction 7 length<sup>1</sup> PG<sup>2</sup> Transaction 7 offset<sup>2</sup> 0x20 ioc EndPt R Device address 0x24 Buffer pointer (page 0) Buffer pointer (page 1) I/O Maximum packet size 0x28 Buffer pointer (Page 2) Reserved Mult 0x2C Buffer pointer (page 3) Reserved 0x30 Buffer pointer (page 4) Reserved 0x34 Buffer pointer (page 5) Reserved 0x38 Buffer pointer (page 6) Reserved 0x3C

Table 17-46. Isochronous transaction descriptor (iTD)

### 17.5.3.1 Next link pointer-iTD

The first DWord of an iTD is a pointer to the next schedule data structure, as shown in the table below.

Table 17-47. Next schedule element pointer

| Bits | Name | Description                                                                                                                                               |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 |      | Correspond to memory address signals [31:5], respectively. This field points to another isochronous transaction descriptor (iTD/siTD) or queue head (QH). |
| 4-3  | -    | Reserved, should be cleared. These bits are reserved and their value has no effect on operation. Software should initialize this field to zero.           |

Host controller read/write; all others read-only.

<sup>2.</sup> These fields may be modified by the host controller if the I/O field indicates an OUT.

Table 17-47. Next schedule element pointer (continued)

| Bits | Name | Description                                                                                                                                                                                                          |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2-1  | Тур  | Indicates to the host controller whether the item referenced is an iTD, siTD or a QH. This allows the host controller to perform the proper type of processing on the item after it is fetched. Value encodings are: |
|      |      | 00 iTD (isochronous transfer descriptor)                                                                                                                                                                             |
|      |      | 01 QH (queue head)                                                                                                                                                                                                   |
|      |      | 10 siTD (split transaction isochronous transfer descriptor)                                                                                                                                                          |
|      |      | 11 FSTN (frame span traversal node)                                                                                                                                                                                  |
| 0    | Т    | Terminate                                                                                                                                                                                                            |
|      |      | 1 Link Pointer field is not valid.                                                                                                                                                                                   |
|      |      | 0 Link Pointer field is valid.                                                                                                                                                                                       |

#### 17.5.3.2 iTD transaction status and control list

DWords 1-8 constitute eight slots of transaction control and status.

Each transaction description includes the following:

- Status results field
- Transaction length (bytes to send for OUT transactions and bytes received for IN transactions).
- Buffer offset. The PG and Transaction *n* Offset fields are used with the buffer pointer list to construct the starting buffer address for the transaction.

The host controller uses the information in each transaction description, plus the endpoint information contained in the first three DWords of the buffer page pointer list, to execute a transaction on the USB.

The table below shows the iTD transaction status and control fields.

Table 17-48. iTD transaction status and control

| Bits  | Name                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28 | Status                  | Records the status of the transaction executed by the host controller for this slot. This field is a bit vector with the following encoding:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |                         | 31 Active. Set by software to enable the execution of an isochronous transaction by the host controller. When the transaction associated with this descriptor is completed, the host controller clears this bit indicating that a transaction for this element should not be executed when it is next encountered in the schedule.                                                                                                                                                                                                                                                                                                            |
|       |                         | 30 Data buffer error. Set by the host controller during status update to indicate that the host controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (underrun). If an overrun condition occurs, no action is necessary.                                                                                                                                                                                                                                                                                                                                 |
|       |                         | 29 Babble detected. Set by the host controller during status update when" babble" is detected during the transaction generated by this descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                         | 28 Transaction error (XactErr). Set by the host controller during status update in the case where the host did not receive a valid response from the device (Time-out, CRC, Bad PID, and so on). This bit may only be set for isochronous IN transactions.                                                                                                                                                                                                                                                                                                                                                                                    |
| 27-16 | Transaction n<br>Length | For an OUT, this field is the number of data bytes the host controller will send during the transaction. The host controller is not required to update this field to reflect the actual number of bytes transferred during the transfer. For an IN, the initial value of the endpoint to deliver. During the status update, the host controller writes back the field is the number of bytes the host expects the number of bytes successfully received. The value in this register is the actual byte count (for example, 0 zero length data, 1 one byte, 2 two bytes, and so on). The maximum value this field may contain is 0xC00 (3072). |
| 15    | ioc                     | Interrupt on complete. If this bit is set, it specifies that when this transaction completes, the host controller should issue an interrupt at the next interrupt threshold.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14-12 | PG                      | These bits are set by software to indicate which of the buffer page pointers the offset field in this slot should be concatenated to produce the starting memory address for this transaction. The valid range of values for this field is 0 to 6.                                                                                                                                                                                                                                                                                                                                                                                            |
| 11-0  | Transaction n<br>Offset | This field is a value that is an offset, expressed in bytes, from the beginning of a buffer. This field is concatenated onto the buffer page pointer indicated in the adjacent PG field to produce the starting buffer address for this transaction.                                                                                                                                                                                                                                                                                                                                                                                          |

### 17.5.3.3 iTD buffer page pointer list (plus)

DWords 9-15 of an isochronous transaction descriptor are nominally page pointers (4K aligned) to the data buffer for this transfer descriptor.

This data structure requires the associated data buffer to be contiguous (relative to virtual memory), but allows the physical memory pages to be non-contiguous. Seven page pointers are provided to support the expression of eight isochronous transfers. The seven pointers allow for 3 (transactions) x 1024 (maximum packet size) x 8 (transaction records) = 24 576 bytes to be moved with this data structure, regardless of the alignment offset of the first page.

Since each pointer is a 4 K-aligned page pointer, the least-significant 12 bits in several of the page pointers are used for other purposes.

The following tables describe buffer pointer page n.

### Table 17-49. Buffer pointer page 0 (Plus)

| Bits  | Name                    | Description                                                                                         |
|-------|-------------------------|-----------------------------------------------------------------------------------------------------|
| 31-12 | Buffer pointer (Page 0) | A 4K-aligned pointer to physical memory. Corresponds to memory address bits 31-12.                  |
| 11-8  | EndPt                   | Selects the particular endpoint number on the device serving as the data source or sink.            |
| 7     | -                       | Reserved, should be cleared. Reserved for future use and should be initialized by software to zero. |
| 6-0   | Device Address          | This field selects the specific device serving as the data source or sink.                          |

### Table 17-50. iTD buffer pointer page 1 (plus)

| Bits  | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | Buffer Pointer<br>(Page 1) | This is a 4K aligned pointer to physical memory. Corresponds to memory address bits 31-12.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11    | I/O                        | Direction (I/O). This field encodes whether the high-speed transaction should use an IN or OUT PID.  0 OUT  1 IN                                                                                                                                                                                                                                                                                                                                                                                           |
| 10-0  | Maximum<br>Packet Size     | This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize). This field is used for high-bandwidth endpoints where more than one transaction is issued per transaction description (for example, per microframe). This field is used with the Multi field to support high-bandwidth pipes. This field is also used for all IN transfers to detect packet babble. Software should not set a value larger than 1024 (0x400). Any value larger yields undefined results. |

### Table 17-51. Buffer pointer page 2 (plus)

| Bits  | Name                    | Description                                                                                                                                    |
|-------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | Buffer pointer (page 2) | This is a 4K-aligned pointer to physical memory. Corresponds to memory address bits 31-12.                                                     |
| 11-2  | -                       | Reserved, should be cleared. This bit reserved for future use and should be cleared.                                                           |
| 1-0   | Mult                    | Indicates to the host controller the number of transactions that should be executed per transaction description (for example, per microframe). |
|       |                         | 00 Reserved, should be cleared. A zero in this field yields undefined results.                                                                 |
|       |                         | 01 One transaction to be issued for this endpoint per microframe                                                                               |
|       |                         | 10 Two transactions to be issued for this endpoint per microframe                                                                              |
|       |                         | 11 Three transactions to be issued for this endpoint per microframe                                                                            |

### Table 17-52. Buffer pointer page 3-6

| Bits  | Name           | Description                                                                                |
|-------|----------------|--------------------------------------------------------------------------------------------|
| 31-12 | Buffer Pointer | This is a 4K aligned pointer to physical memory. Corresponds to memory address bits 31-12. |
| 11-0  | -              | Reserved, should be cleared. These bits reserved for future use and should be cleared.     |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

# 17.5.4 Split transaction isochronous transfer descriptor (siTD)

All full-speed isochronous transfers through the internal transaction translator are managed using the siTD data structure.

This data structure satisfies the operational requirements for managing the split transaction protocol.

The table below shows the split-transaction isochronous transfer descriptor (siTD).

Table 17-53. Split-transaction isochronous transaction descriptor (siTD)

| 31                      | 3                     | 2<br>9 | 2   | 2<br>7 | 2<br>6 | 2<br>5 | 2        | 2                           | 2    | 2    | 2    | 1<br>9          | 1<br>8 | 1 7 | 1<br>6         | 15                                                  | 1 4 | 1<br>3 | 1 2 | 1              | 1 | 9 | 8    | 7         | 6    | 5 | 4  | 3 | 2    | 1 | 0 | offset |
|-------------------------|-----------------------|--------|-----|--------|--------|--------|----------|-----------------------------|------|------|------|-----------------|--------|-----|----------------|-----------------------------------------------------|-----|--------|-----|----------------|---|---|------|-----------|------|---|----|---|------|---|---|--------|
| Nex                     | t Lir                 | nk F   | oin | ter    |        |        | •        | •                           |      | •    |      | •               | •      |     | •              | •                                                   |     |        | •   |                | • | • |      | •         | •    |   | 00 |   | Тур  | ) | Т | 0x00   |
| I/O                     | Ро                    | rt N   | uml | oer    |        |        |          | 0                           | Hu   | ıb A | ddre | ess             |        |     |                | 0000                                                | )   |        |     | EndPt 0 Device |   |   | vice | e Address |      |   |    |   | 0x04 |   |   |        |
| 000                     | 0_0                   | 000    | _00 | 00_    | _000   | 000    |          |                             |      |      |      |                 |        |     |                | μFrame C-mask μFrame                                |     |        | e S | 3-mask         |   |   |      |           | 0x08 |   |    |   |      |   |   |        |
| ioc                     | P <sup>1</sup>        | 00     | 00  |        |        | То     | tal E    | 3yte                        | s to | Tra  | ansf | er <sup>1</sup> |        |     |                | μFrame C-prog-mask <sup>1</sup> Status <sup>1</sup> |     |        | 1   |                |   |   |      |           | 0x0C |   |    |   |      |   |   |        |
| Buffer Pointer (Page 0) |                       |        |     |        |        |        |          | Current Offset <sup>1</sup> |      |      |      |                 |        |     | 0x10           |                                                     |     |        |     |                |   |   |      |           |      |   |    |   |      |   |   |        |
| Buffer Pointer (Page 1) |                       |        |     |        |        |        | 000_0000 |                             |      |      | TP   | 1               | Т-с    | our | t <sup>1</sup> | 0x14                                                |     |        |     |                |   |   |      |           |      |   |    |   |      |   |   |        |
| Bac                     | Back Pointer 0000 T 0 |        |     |        |        |        |          |                             | 0x18 |      |      |                 |        |     |                |                                                     |     |        |     |                |   |   |      |           |      |   |    |   |      |   |   |        |

<sup>1.</sup> Host controller read/write; all others read-only.

### 17.5.4.1 Next link pointer-siTD

DWord0 of a siTD is a pointer to the next schedule data structure.

The table below describes the next link pointer fields.

Table 17-54. Next link pointer

| Bits | Name                 | Description                                                                                                                                                                                                         |
|------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | Next Link<br>Pointer | This field contains the address of the next data object to be processed in the periodic list and corresponds to memory address signals [31:5], respectively.                                                        |
| 4-3  | -                    | Reserved, should be cleared. These bits must be written as zeros.                                                                                                                                                   |
| 2-1  | Тур                  | Indicates to the host controller whether the item referenced is an iTD/siTD or a QH. This allows the host controller to perform the proper type of processing on the item after it is fetched. Value encodings are: |
|      |                      | 00 iTD (isochronous transfer descriptor)                                                                                                                                                                            |
|      |                      | 01 QH (queue head)                                                                                                                                                                                                  |
|      |                      | 10 siTD (split transaction isochronous transfer descriptor                                                                                                                                                          |
|      |                      | 11 FSTN (frame span traversal node)                                                                                                                                                                                 |

Table 17-54. Next link pointer (continued)

| Bits | Name | Description                        |
|------|------|------------------------------------|
| 0    | Т    | Terminate.                         |
|      |      | 0 Link pointer is valid.           |
|      |      | 1 Link pointer field is not valid. |

### 17.5.4.2 siTD endpoint capabilities/characteristics

DWords 1 and 2 specify static information about the full-speed endpoint, the addressing of the parent Companion Controller, and microframe scheduling control.

The table below describes the endpoint and transaction translator characteristics.

Table 17-55. Endpoint and transaction translator characteristics

| Bits  | Name           | Description                                                                                               |
|-------|----------------|-----------------------------------------------------------------------------------------------------------|
| 31    | I/O            | Direction (I/O). This field encodes whether the full-speed transaction should be an IN or OUT.            |
|       |                | 0 OUT                                                                                                     |
|       |                | 1 IN                                                                                                      |
| 30-24 | Port Number    | This field is the port number of the recipient transaction translator.                                    |
| 23    | -              | Reserved, should be cleared. Bit reserved and should be cleared.                                          |
| 22-16 | Hub Address    | This field holds the device address of the companion controllers' hub.                                    |
| 15-12 | -              | Reserved, should be cleared. Field reserved and should be cleared.                                        |
| 11-8  | EndPt          | Endpoint Number. Selects the particular endpoint number on the device serving as the data source or sink. |
| 7     | -              | Reserved, should be cleared. Bit is reserved for future use. It should be cleared.                        |
| 6-0   | Device Address | Selects the specific device serving as the data source or sink.                                           |

The table below describes the microframe schedule control.

Table 17-56. Microframe schedule control

| Bits  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | -    | Reserved, should be cleared. This field reserved for future use. It should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15-8  |      | Split completion mask. This field (along with the Active and SplitX- state fields in the status byte) is used to determine during which microframes the host controller should execute complete-split transactions. When the criteria for using this field is met, an all-zeros value has undefined behavior. The host controller uses the value of the three low-order bits of the FRINDEX register to index into this bit field. If the FRINDEX register value indexes to a position where the µFrame C-Mask field is a one, this siTD is a candidate for transaction execution. There may be more than one bit in this mask set. |

#### Host data structures

### Table 17-56. Microframe schedule control (continued)

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0  |      | Split start mask. This field (along with the Active and SplitX-state fields in the Status byte) is used to determine during which microframes the host controller should execute start-split transactions. The host controller uses the value of the three low-order bits of the FRINDEX register to index into this bit field. If the FRINDEX register value indexes to a position where the $\mu$ Frame S-mask field is a one, then this siTD is a candidate for transaction execution. An all zeros value in this field, in combination with existing periodic frame list has undefined results. |

### 17.5.4.3 siTD transfer state

DWords 3-6 manage the state of the transfer, as described in the table below.

Table 17-57. siTD transfer status and control

| Bits  | Name                       | Description                                                                                                                                                                                    |
|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | ioc                        | Interrupt on complete                                                                                                                                                                          |
|       |                            | 0 Do not interrupt when transaction is complete.                                                                                                                                               |
|       |                            | 1 Do interrupt when transaction is complete. When the host controller determines that the split transaction has completed it will assert a hardware interrupt at the next interrupt threshold. |
| 30    | Р                          | Page select. Indicates which data page pointer should be concatenated with the CurrentOffset field to construct a data buffer pointer                                                          |
|       |                            | 0 Selects Page 0 pointer                                                                                                                                                                       |
|       |                            | 1 Selects Page 1 pointer                                                                                                                                                                       |
|       |                            | The host controller is not required to write this field back when the siTD is retired (Active bit transitioned from a one to a zero).                                                          |
| 29-26 | -                          | Reserved, should be cleared. This field reserved for future use and should be cleared.                                                                                                         |
| 25-16 | Total Bytes to<br>Transfer | This field is initialized by software to the total number of bytes expected in this transfer. Maximum value is 1023 (3FFh)                                                                     |
| 15-8  | μFrame C-<br>prog-mask     | Split complete progress mask. This field is used by the host controller to record which split-completes have been executed.                                                                    |

Table 17-57. siTD transfer status and control (continued)

| Bits | Name   |                                                                                                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7-0  | Status | This field records the status of the transaction executed by the host controller for this slot. This field is a bit vector with the following encoding: |                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|      |        | Status Bits                                                                                                                                             | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|      |        | 7                                                                                                                                                       | Active. Set by software to enable the execution of an isochronous split transaction by the host controller.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|      |        | 6                                                                                                                                                       | ERR. Set by the host controller when an ERR response is received from the companion controller.                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|      |        | 5                                                                                                                                                       | Data buffer error. Set by the host controller during status update to indicate that the host controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (under run). In the case of an under run, the host controller will transmit an incorrect CRC (thus invalidating the data at the endpoint). If an overrun condition occurs, no action is necessary. |  |  |  |  |  |
|      |        | 4                                                                                                                                                       | Babble detected. Set by the host controller during status update when" babble" is detected during the transaction generated by this descriptor.                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|      |        | 3                                                                                                                                                       | Transaction error (XactErr). Set by the host controller during status update in the case where the host did not receive a valid response from the device (Time-out, CRC, Bad PID, and so on). This bit will only be set for IN transactions.                                                                                                                                                                                              |  |  |  |  |  |
|      |        | 2                                                                                                                                                       | Missed microframe. The host controller detected that a host-induced hold- off caused the host controller to miss a required complete-split transaction.                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|      |        | 1                                                                                                                                                       | Split transaction state (SplitXstate). The bit encodings are:                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|      |        |                                                                                                                                                         | 0 Do start split. This value directs the host controller to issue a Start split transaction to the endpoint when a match is encountered in the S-mask.                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|      |        |                                                                                                                                                         | 1 Do complete split. This value directs the host controller to issue a Complete split transaction to the endpoint when a match is encountered in the C-mask.                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|      |        | 0                                                                                                                                                       | Reserved, should be cleared. Bit reserved for future use and should be cleared.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |

# 17.5.4.4 siTD buffer pointer list (plus)

DWords 4 and 5 are the data buffer page pointers for the transfer.

This structure supports one physical page cross. The most-significant 20 bits of each DWord in this section are the 4K (page) aligned buffer pointers. The least-significant 12 bits of each DWord are used as additional transfer state.

The table below describes the siTD buffer pointer page 0.

Table 17-58. siTD buffer pointer page 0 (plus)

| Bits  | Name | Description                                                                                                                                                                                                                                                                                            |
|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 |      | Bits 31-12 are 4K page-aligned, physical memory addresses. These bits correspond to physical address bits 31-12 respectively. The field P specifies the current active pointer                                                                                                                         |
| 11-0  |      | The 12 least-significant bits of the Page 0 pointer is the current byte offset for the current page pointer (as selected with the page indicator bit (P field)). The host controller is not required to write this field back when the siTD is retired (Active bit transitioned from a one to a zero). |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

The table below describes the siTD buffer pointer page 1.

Table 17-59. siTD buffer pointer page 1 (plus)

| Bits  | Name                       | Description                                                                                                                                                                                                                                                                                                                                             |
|-------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | Buffer Pointer<br>(Page 1) | Bits 31-12 are 4K page-aligned, physical memory addresses. These bits correspond to physical address bits 31-12 respectively. The field P specifies the current active pointer                                                                                                                                                                          |
| 11-5  | -                          | Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                            |
| 4-3   | ТР                         | Transaction position. This field is used with T-count to determine whether to send all, first, middle, or last with each outbound transaction payload. System software must initialize this field with the appropriate starting value. The host controller must correctly manage this state during the lifetime of the transfer. The bit encodings are: |
|       |                            | 00 All. The entire full-speed transaction data payload is in this transaction (that is, less than or equal to 188 bytes).                                                                                                                                                                                                                               |
|       |                            | 01 Begin. This is the first data payload for a full-speed transaction that is greater than 188 bytes.                                                                                                                                                                                                                                                   |
|       |                            | 10 Mid. This is the middle payload for a full-speed OUT transaction that is larger than 188 bytes.                                                                                                                                                                                                                                                      |
|       |                            | 11 End. This is the last payload for a full-speed OUT transaction that was larger than 188 bytes.                                                                                                                                                                                                                                                       |
| 2-0   | T-Count                    | Transaction count. Software initializes this field with the number of OUT start-splits this transfer requires. Any value larger than 6 is undefined.                                                                                                                                                                                                    |

### 17.5.4.5 siTD back link pointer

DWord 6 of a siTD is simply another schedule link pointer.

This pointer is always zero, or references a siTD. This pointer cannot reference any other schedule data structure.

The table below describes the siTD back link pointer.

Table 17-60. siTD back link pointer

| Bits | Name         | Description                                                                               |
|------|--------------|-------------------------------------------------------------------------------------------|
| 31-5 | Back Pointer | A physical memory pointer to an siTD                                                      |
| 4-1  | -            | Reserved, should be cleared. This field is reserved for future use. It should be cleared. |
| 0    | Т            | Terminate                                                                                 |
|      |              | 0 siTD Back Pointer field is valid                                                        |
|      |              | 1 siTD Back Pointer field is not valid                                                    |

### 17.5.5 Queue element transfer descriptor (qTD)

This data structure is only used with a queue head.

This data structure is used for one or more USB transactions. This data structure is used to transfer up to 20,480 (5 x 4096) bytes. The structure contains two structure pointers used for queue advancement, a DWord of transfer state, and a five-element array of data buffer pointers. This structure is 32 bytes (or one 32-byte cache line). This data structure must be physically contiguous.

The buffer associated with this transfer must be virtually contiguous. The buffer may start on any byte boundary. A separate buffer pointer list element must be used for each physical page in the buffer, regardless of whether the buffer is physically contiguous.

Host controller updates (host controller writes) to stand-alone qTDs only occur during transfer retirement. References in the following bit field definitions of updates to the qTD are to the qTD portion of a queue head.

The table below shows the queue element transfer descriptors.

30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 offset Next qTD Pointer 0000 0x00 Alternate Next qTD Pointer 0000 0x04 Total Bytes to Transfer<sup>1</sup> ioc | C\_Page<sup>1</sup> Cerr<sup>1</sup> PID Status<sup>1</sup> 80x0 Code Current Offset<sup>1</sup> Buffer Pointer (Page 0) 0x0C Buffer Pointer (Page 1) 0000\_0000\_0000 0x10 Buffer Pointer (Page 2) 0000\_0000\_0000 0x14

0000 0000 0000

0000\_0000\_0000

Table 17-61. Queue element transfer descriptor (qTD)

Buffer Pointer (Page 3)

Buffer Pointer (Page 4)

Queue element transfer descriptors must be aligned on 32-byte boundaries.

## 17.5.5.1 Next qTD pointer

The first DWord of an element transfer descriptor is a pointer to another transfer element descriptor.

The table below describes the qTD next element transfer pointer.

Table 17-62. qTD next element transfer pointer (DWord 0)

| Bits | Name | Description                                                                                                                                     |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      | This field contains the physical memory address of the next qTD to be processed and corresponds to memory address signals [31:5], respectively. |
| 4-1  | -    | Reserved, should be cleared. These bits are reserved and their value has no effect on operation.                                                |

Table continues on the next page...

## P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

0x18

0x1C

<sup>1.</sup> Host controller read/write; all others read-only.

Table 17-62. qTD next element transfer pointer (DWord 0) (continued)

| Bits | Name | Description                                                                                    |
|------|------|------------------------------------------------------------------------------------------------|
| 0    | Т    | Terminate. Indicates to the host controller that there are no more valid entries in the queue. |
|      |      | 0 Pointer is valid (points to a valid transfer element descriptor)                             |
|      |      | 1 Pointer is invalid                                                                           |

## 17.5.5.2 Alternate next qTD pointer

The second DWord of a queue element transfer descriptor is used to support hardwareonly advance of the data stream to the next client buffer on short packet.

To be more explicit the host controller will always use this pointer when the current qTD is retired due to short packet. The table below describes the alternate qTD next element transfer pointer.

Table 17-63. qTD alternate next element transfer pointer (DWord 1)

| Bits | Name                       | Description                                                                                                                                                                                                                                          |
|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | Alternate next qTD pointer | This field contains the physical memory address of the next qTD to be processed in the event that the current qTD execution encounters a short packet (for an IN transaction). The field corresponds to memory address signals [31:5], respectively. |
| 4-1  | -                          | Reserved, should be cleared. These bits are reserved and their value has no effect on operation.                                                                                                                                                     |
| 0    | Т                          | Terminate. Indicates to the host controller that there are no more valid entries in the queue.                                                                                                                                                       |
|      |                            | 0 Pointer is valid (points to a valid transfer element descriptor)                                                                                                                                                                                   |
|      |                            | 1 Pointer is invalid                                                                                                                                                                                                                                 |

## 17.5.5.3 qTD token

The third DWord of a queue element transfer descriptor contains most of the information the host controller requires to execute a USB transaction (the remaining endpoint-addressing information is specified in the queue head).

Note that some of the field descriptions in the table below reference fields are defined in the queue head. See Queue head, for more information on these fields.

Table 17-64. qTD token (DWord 2)

| Bits | Name | Description                                                                                                                                     |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   |      | Data toggle. This is the data toggle sequence bit. The use of this bit depends on the setting of the Data Toggle Control bit in the queue head. |

# Table 17-64. qTD token (DWord 2) (continued)

| Bits  | Name                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|-------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 30-16 | Total bytes to transfer | descriptor. This field transaction, only on may store in this fie can access. If the v (and the active bit is transfer descriptor. multiple of QH[Max transfer, the last transpossible to create a predetermined, crossible to create and transfer, descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Total bytes to transfer. This field specifies the total number of bytes to be moved with this transfer descriptor. This field is decremented by the number of bytes actually moved during the transaction, only on the successful completion of the transaction. The maximum value software may store in this field is 5 x 4K (0x5000). This is the maximum number of bytes 5 page pointers can access. If the value of this field is zero when the host controller fetches this transfer descriptor (and the active bit is set), the host controller executes a zero-length transaction and retires the transfer descriptor. It is not a requirement for OUT transfers that total bytes to transfer be an even multiple of QH[Maximum Packet Length]. If software builds such a transfer descriptor for an OUT transfer, the last transaction will always be less than QH[Maximum Packet Length]. Although it is possible to create a transfer up to 20K this assumes the page is 0. When the offset cannot be predetermined, crossing past the 5th page can be guaranteed by limiting the total bytes to 16K. Therefore, the maximum recommended transfer is 16K (0x4000). |  |  |  |  |  |  |  |
| 15    | ioc                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | te. If this bit is set, the host controller should issue an interrupt at the next when this qTD is completed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| 14-12 | C_Page                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | field is used as an index into the qTD buffer pointer list. Valid values are in the he host controller is not required to write this field back when the qTD is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| 11-10 | Cerr                    | Error counter. 2-bit down counter that keeps track of the number of consecutive errors de while executing this qTD. If this field is programmed with a non-zero value during setup, to controller decrements the count and writes it back to the qTD if the transaction fails. If the counts from one to zero, the host controller marks the qTD inactive, sets the Halted bit to and error status bit for the error that caused Cerr to decrement to zero. An interrupt is ger USBINTR[UEE] is set. If the host controller driver (HCD) software programs this field to z during setup, the host controller will not count errors for this qTD and there is no limit on to fi this qTD. Note that write-backs of intermediate execution state are to the queue head carea, not the qTD. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|       |                         | Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Decrement Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|       |                         | Transaction Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|       |                         | Data Buffer Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | No. Data buffer errors are host problems. They don't count against the device's retries. Note that software must not program Cerr to a value of zero when the EPS field is programmed with a value indicating a full- or low-speed device. This combination could result in undefined behavior.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|       |                         | Stalled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | No. Detection of babble or stall automatically halts the queue head. Thus, count is not decremented                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|       |                         | Babble Detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | No. Detection of babble or stall automatically halts the queue head. Thus, count is not decremented                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|       |                         | No Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No. If the EPS field indicates a HS device or the queue head is in the asynchronous schedule (and PIDCode indicates an IN or OUT) and a bus transaction completes and the host controller does not detect a transaction error, then the host controller should reset Cerr to extend the total number of errors for this transaction. For example, Cerr should be reset with maximum value (0b11) on each successful completion of a transaction. The host controller must never reset this field if the value at the start of the transaction is 0b00.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |

# Table 17-64. qTD token (DWord 2) (continued)

| Bits | Name     |                                                                                                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 9-8  | PID Code | This field is an encoding of the token, which should be used for transactions associated with transfer descriptor. Encodings are: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|      |          | 00 OUT Token gener                                                                                                                | rates token (E1H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|      |          | 01 IN Token generat                                                                                                               | es token (69H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|      |          |                                                                                                                                   | nerates token (2DH) (undefined if endpoint is an Interrupt transfer type, for mask field in the queue head is non-zero.)                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|      |          | 11 Reserved, should                                                                                                               | be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| 7-0  | Status   | to the host controller                                                                                                            | the host controller to communicate individual command execution states back driver (HCD) software. This field contains the status of the last transaction D. The bit encodings are:                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|      |          | Bits                                                                                                                              | Status Field Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|      |          | 7                                                                                                                                 | Active. Set by software to enable the execution of transactions by the host controller.                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|      |          | 6                                                                                                                                 | Halted. Set by the host controller during status updates to indicate that a serious error has occurred at the device/endpoint addressed by this qTD. This can be caused by babble, the error counter counting down to zero, or reception of the STALL handshake from the device during a transaction. Any time that a transaction results in the Halted bit being set, the Active bit is also cleared.                                                                                                 |  |  |  |  |  |  |  |
|      |          | 5                                                                                                                                 | Data buffer error. Set by the host controller during status update to indicate that the host controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (under run). If an overrun condition occurs, the host controller will force a time-out condition on the USB, invalidating the transaction at the source. If the host controller sets this bit to a one, then it remains a one for the duration of the transfer. |  |  |  |  |  |  |  |
|      |          | 4                                                                                                                                 | Babble detected. Set by the host controller during status update when babble is detected during the transaction. In addition to setting this bit, the host controller also sets the Halted bit to a one. Since babble is considered a fatal error for the transfer, setting the Halted bit to a one insures that no more transactions occur because of this descriptor.                                                                                                                                |  |  |  |  |  |  |  |
|      |          | 3                                                                                                                                 | Transaction error (XactErr). Set by the host controller during status update in the case where the host did not receive a valid response from the device (time-out, CRC, bad PID). If the host controller sets this bit to a one, then it remains a one for the duration of the transfer.                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|      |          | 2                                                                                                                                 | Missed microframe. This bit is ignored unless the QH[EPS] field indicates a full- or low-speed endpoint and the queue head is in the periodic list. This bit is set when the host controller detected that a host-induced hold-off caused the host controller to miss a required complete-split transaction. If the host controller sets this bit to a one, then it remains a one for the duration of the transfer.                                                                                    |  |  |  |  |  |  |  |

Table 17-64. qTD token (DWord 2) (continued)

| Bits | Name |   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      | 1 | Split transaction state (SplitXstate). This bit is ignored by the host controller unless the QH[EPS] field indicates a full- or low-speed endpoint. When a full- or low-speed device, the host controller uses this bit to track the state of the split- transaction. The functional requirements of the host controller for managing this state bit and the split transaction protocol depends on whether the endpoint is in the periodic or asynchronous schedule. The bit encodings are: |
|      |      |   | 0 Do start split. This value directs the host controller to issue a start split transaction to the endpoint.                                                                                                                                                                                                                                                                                                                                                                                |
|      |      |   | Do complete split. This value directs the host controller to issue a     Complete split transaction to the endpoint.                                                                                                                                                                                                                                                                                                                                                                        |
|      |      | 0 | Ping state (P)/ERR. If the QH[EPS] field indicates a high-speed device and the PID Code indicates an OUT endpoint, then this is the state bit for the Ping protocol. The bit encodings are:                                                                                                                                                                                                                                                                                                 |
|      |      |   | 0 Do OUT. This value directs the host controller to issue an OUT PID to the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                       |
|      |      |   | 1 Do Ping. This value directs the host controller to issue a PING PID to the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                      |
|      |      |   | If the QH[EPS] field does not indicate a high-speed device, then this field is used as an error indicator bit. It is set by the host controller whenever a periodic split-transaction receives an ERR handshake.                                                                                                                                                                                                                                                                            |

# 17.5.5.4 qTD buffer page pointer list

The last five DWords of a queue element transfer descriptor make up an array of physical memory address pointers.

These pointers reference the individual pages of a data buffer.

System software initializes the Current Offset field to the starting offset into the current page, where current page is selected with the value in the C\_Page field.

The table below describes the qTD buffer pointer.

Table 17-65. qTD buffer pointer

| Bits  | Name                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | Buffer pointer (page <i>n</i> ) | Each element in the list is a 4K page aligned physical memory address. The lower 12 bits in each pointer are reserved (except for the first one), as each memory pointer must reference the start of a 4K page. The field C_Page specifies the current active pointer. When the transfer element descriptor is fetched, the starting buffer address is selected using C_Page (similar to an array index to select an array element). If a transaction spans a 4K buffer boundary, the host controller must detect the page-span boundary in the data stream, increment C_Page and advance to the next buffer pointer in the list, and conclude the transaction via the new buffer pointer. |

## Table 17-65. qTD buffer pointer (continued)

| Bits | Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-0 | Current offset<br>(Page 0)/ -<br>(pages 1-4) | Reserved in all pointers except the first one (that is, page 0). The host controller should ignore all reserved bits. For the page 0 current offset interpretation, this field is the byte offset into the current page (as selected by C_Page). The host controller is not required to write this field back when the qTD is retired. Software should ensure the reserved fields are initialized to zeros. |

## 17.5.6 Queue head

The table below shows the queue head structure.

Table 17-66. Queue head layout

| 31                                                            | 3     | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2              | 2              | 2    | 2                 | 2   | 1<br>9            | 1<br>8              | 1<br>7 |   | 15               | 14  | 1 3 | 1 2            | 1<br>1                                    | 1                 | 9     | 8                  | 7  | 6   | 5                   | 4    | 3    | 2               | 1 | 0              | offset              |
|---------------------------------------------------------------|-------|--------|--------|--------|--------|--------|----------------|----------------|------|-------------------|-----|-------------------|---------------------|--------|---|------------------|-----|-----|----------------|-------------------------------------------|-------------------|-------|--------------------|----|-----|---------------------|------|------|-----------------|---|----------------|---------------------|
| Que                                                           | eue   | Hea    | ad F   | lori   | zor    | nta    | ıl Lir         | ık l           | Poir | ntei              | r   |                   |                     |        | - |                  | !   | -   | -              | -                                         | -                 |       | -                  | !  | -   |                     | 00   | )    | Тур             | ) | Т              | 0x00 <sup>1</sup>   |
| RL                                                            |       |        |        | С      | M      | axi    | imuı           | m F            | Pac  | ket               | Le  | ngt               | h                   |        |   | Н                | dtc | EF  | S              | En                                        | dPt               |       |                    | I  | De  | vic                 | e Ad | ddre | ss              |   |                | 0x04 <sup>1</sup>   |
| Mul                                                           | t     | Po     | rt N   | um     | be     | r      |                |                | Н    | ub /              | Add | dr                |                     |        |   | μFra             | me  | C-m | ask            |                                           |                   |       |                    | μF | ram | ne S                | S-ma | ask  |                 |   |                | 0x08                |
| Cur                                                           | ren   | t qT   | DΡ     | oin    | ter    | 2      |                |                | •    |                   |     |                   |                     |        |   |                  |     |     |                |                                           |                   |       |                    |    |     |                     | 00   | 000  |                 |   |                | 0x0C                |
| Nex                                                           | t q   | TD F   | oin    | ter    | 2      |        |                |                |      |                   |     |                   |                     |        |   |                  |     |     |                |                                           |                   |       |                    |    |     |                     | 00   | 00   |                 |   | T <sup>2</sup> | 0x10 <sup>3,4</sup> |
| Alte                                                          | rna   | te N   | lext   | qΤ     | D F    | Poi    | inte           | 2              |      |                   |     |                   |                     |        |   |                  |     |     |                |                                           |                   |       |                    |    |     |                     | Na   | akCr | nt <sup>2</sup> |   | T <sup>2</sup> | 0x14 <sup>3,4</sup> |
| dt <sup>2</sup>                                               | То    | tal E  | Byte   | s to   | ΣТ     | rai    | nsfe           | r <sup>2</sup> |      |                   |     |                   |                     |        |   | ioc <sup>2</sup> | C_I | ⊃ag | e <sup>2</sup> | Cerr <sup>2</sup> PID Status <sup>2</sup> |                   |       |                    |    | '   | 0x18 <sup>3,4</sup> |      |      |                 |   |                |                     |
| Buff                                                          | fer I | Poin   | ter    | (Pa    | ıge    | 0)     | ) <sup>2</sup> |                |      |                   |     |                   |                     |        |   |                  |     |     |                | Сι                                        | ırrer             | nt Of | ffset <sup>2</sup> |    |     |                     |      |      |                 |   |                | 0x1C <sup>3,4</sup> |
| Buff                                                          | fer I | Poin   | ter    | (Pa    | ıge    | 1)     | ) <sup>2</sup> |                |      |                   |     |                   |                     |        |   |                  |     |     |                | 00                                        | 00                |       |                    | C- | pro | g-m                 | ask  | 2    |                 |   |                | 0x20 <sup>3,4</sup> |
| Buffer Pointer (Page 2) <sup>2</sup> S-bytes <sup>2</sup> Fra |       |        |        |        |        |        |                |                |      | Fra               | meT | ag <mark>2</mark> | 0x24 <sup>3,4</sup> |        |   |                  |     |     |                |                                           |                   |       |                    |    |     |                     |      |      |                 |   |                |                     |
| Buffer Pointer (Page 3) <sup>2</sup>                          |       |        |        |        |        |        |                |                | 00   | 00_               | 000 | 0_00              | 00                  |        |   |                  |     |     |                |                                           | 0x28 <sup>3</sup> |       |                    |    |     |                     |      |      |                 |   |                |                     |
| Buffer Pointer (Page 4) <sup>2</sup> 0000_0000_0000           |       |        |        |        |        |        |                |                |      | 0x2C <sup>3</sup> |     |                   |                     |        |   |                  |     |     |                |                                           |                   |       |                    |    |     |                     |      |      |                 |   |                |                     |

- 1. Offsets 0x00 through 0x07 contain the static endpoint state.
- 2. Host controller read/write; all others read-only.
- 3. Offsets 0x10 through 0x2F contain the transfer overlay.
- 4. Offsets 0x10 through 0x27 contain the transfer results.

## 17.5.6.1 Queue head horizontal link pointer

The first DWord of a queue head contains a link pointer to the next data object to be processed after any required processing in this queue has been completed, as well as the control bits defined below.

This pointer may reference a queue head or one of the isochronous transfer descriptors. It must not reference a queue element transfer descriptor.

The table below describes the queue head.

### Table 17-67. Queue head DWord 0

| Bits | Name | Description                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | QHLP | Queue head horizontal link pointer. This field contains the address of the next data object to be processed in the horizontal list and corresponds to memory address signals [31:5], respectively.                                                                                                                                                                               |
| 4-3  | -    | Reserved, should be cleared. These bits must be written as zeros.                                                                                                                                                                                                                                                                                                                |
| 2-1  | Тур  | Indicates to the hardware whether the item referenced by the link pointer is an iTD, siTD or a QH. This allows the host controller to perform the proper type of processing on the item after it is fetched.                                                                                                                                                                     |
|      |      | 00 iTD (isochronous transfer descriptor)                                                                                                                                                                                                                                                                                                                                         |
|      |      | 01 QH (queue head)                                                                                                                                                                                                                                                                                                                                                               |
|      |      | 10 siTD (split transaction isochronous transfer descriptor)                                                                                                                                                                                                                                                                                                                      |
|      |      | 11 FSTN (frame span traversal node)                                                                                                                                                                                                                                                                                                                                              |
| 0    | Т    | Terminate.                                                                                                                                                                                                                                                                                                                                                                       |
|      |      | 1 Last QH (pointer is invalid).                                                                                                                                                                                                                                                                                                                                                  |
|      |      | 0 Pointer is valid.                                                                                                                                                                                                                                                                                                                                                              |
|      |      | If the queue head is in the context of the periodic list, a one bit in this field indicates to the host controller that this is the end of the periodic list. This bit is ignored by the host controller when the queue head is in the asynchronous schedule. Software must ensure that queue heads reachable by the host controller always have valid horizontal link pointers. |

## 17.5.6.2 Endpoint capabilities/characteristics

The second and third DWords of a queue head specify static information about the endpoint.

This information does not change over the lifetime of the endpoint. There are three types of information in this region:

- Endpoint characteristics. These are the USB endpoint characteristics, which include addressing, maximum packet size, and endpoint speed.
- Endpoint capabilities. These are adjustable parameters of the endpoint. They affect how the endpoint data stream is managed by the host controller.
- Split transaction characteristics. This data structure manages full- and low-speed data streams for bulk, control, and interrupt with split transactions to USB 2.0 Hub transaction translator. Additional fields exist for addressing the hub and scheduling the protocol transactions (for periodic).

The host controller must not modify the bits in this region.

The following tables describe the endpoint characteristics.

Table 17-68. Endpoint characteristics: Queue head DWord 1

|       | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28 | RL                    | Nak count reload. This field contains a value, which is used by the host controller to reload the Nak Counter field.                                                                                                                                                                                                                                                                                                  |
| 27    | С                     | Control endpoint flag. If the QH[EPS] field indicates the endpoint is not a high-speed device, and the endpoint is a control endpoint, then software must set this bit to a one. Otherwise, it should always set this bit to a zero.                                                                                                                                                                                  |
| 26-16 | Maximum packet length | This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize). The maximum value this field may contain is 0x400 (1024).                                                                                                                                                                                                                                                           |
| 15    | Н                     | Head of reclamation list flag. This bit is set by system software to mark a queue head as being the head of the reclamation list.                                                                                                                                                                                                                                                                                     |
| 14    | dtc                   | Data toggle control (DTC). Specifies where the host controller should get the initial data toggle on an overlay transition.                                                                                                                                                                                                                                                                                           |
|       |                       | 0 Ignore DT bit from incoming qTD. Host controller preserves DT bit in the queue head.                                                                                                                                                                                                                                                                                                                                |
|       |                       | 1 Initial data toggle comes from incoming qTD DT bit. Host controller replaces DT bit in the queue head from the DT bit in the qTD.                                                                                                                                                                                                                                                                                   |
| 13-12 | EPS                   | Endpoint speed. This is the speed of the associated endpoint.                                                                                                                                                                                                                                                                                                                                                         |
|       |                       | 00 Full-speed (12 Mbps)                                                                                                                                                                                                                                                                                                                                                                                               |
|       |                       | 01 Low-speed (1.5 Mbps)                                                                                                                                                                                                                                                                                                                                                                                               |
|       |                       | 10 High-speed (480 Mbps)                                                                                                                                                                                                                                                                                                                                                                                              |
|       |                       | 11 Reserved, should be cleared This field must not be modified by the host controller.                                                                                                                                                                                                                                                                                                                                |
| 11-8  | EndPt                 | Endpoint number. Selects the particular endpoint number on the device serving as the data source or sink.                                                                                                                                                                                                                                                                                                             |
| 7     | I                     | Inactivate on next transaction. This bit is used by system software to request that the host controller set the Active bit to zero. This field is only valid when the queue head is in the periodic schedule and the EPS field indicates a full- or low-speed endpoint. Setting this bit when the queue head is in the asynchronous schedule or the EPS field indicates a high-speed device yields undefined results. |
| 6-0   | Device address        | Selects the specific device serving as the data source or sink.                                                                                                                                                                                                                                                                                                                                                       |

Table 17-69. Endpoint capabilities: Queue head DWord 2

| Bits  | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Mult        | High-bandwidth pipe multiplier. This field is a multiplier used to key the host controller as the number of successive packets the host controller may submit to the endpoint in the current execution. The host controller makes the simplifying assumption that software properly initializes this field (regardless of location of queue head in the schedules or other run time parameters). |
|       |             | 00 Reserved, should be cleared. A zero in this field yields undefined results.                                                                                                                                                                                                                                                                                                                   |
|       |             | 01 One transaction to be issued for this endpoint per microframe                                                                                                                                                                                                                                                                                                                                 |
|       |             | 10 Two transactions to be issued for this endpoint per microframe                                                                                                                                                                                                                                                                                                                                |
|       |             | 11 Three transactions to be issued for this endpoint per microframe                                                                                                                                                                                                                                                                                                                              |
| 29-23 | Port number | This field is ignored by the host controller unless the EPS field indicates a full- or low-speed device. The value is the port number identifier on the USB 2.0 hub (for hub at device address Hub Addr below), below which the full- or low-speed device associated with this endpoint is attached. This information is used in the split-transaction protocol.                                 |

Table 17-69. Endpoint capabilities: Queue head DWord 2 (continued)

| Bits  | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22-16 | Hub addr      | This field is ignored by the host controller unless the EPS field indicates a full-or low-speed device. The value is the USB device address of the USB 2.0 hub below which the full- or low-speed device associated with this endpoint is attached. This field is used in the split-transaction protocol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15-8  | μFrame C-mask | This field is ignored by the host controller unless the EPS field indicates this device is a low- or full-speed device and this queue head is in the periodic list. This field (along with the Active and SplitX-state fields) is used to determine during which microframes the host controller should execute a complete-split transaction. When the criteria for using this field are met, a zero value in this field has undefined behavior. This field is used by the host controller to match against the three low-order bits of the FRINDEX register. If the FRINDEX register bits decode to a position where the $\mu Frame\ C$ - mask field is a one, then this queue head is a candidate for transaction execution. There may be more than one bit in this mask set.                                                                                                                                                                                                                               |
| 7-0   | μFrame S-mask | Interrupt schedule mask. This field is used for all endpoint speeds. Software should set this field to a zero when the queue head is on the asynchronous schedule. A non-zero value in this field indicates an interrupt endpoint. The host controller uses the value of the three low-order bits of the FRINDEX register as an index into a bit position in this bit vector. If the $\mu$ Frame S-mask field has a one at the indexed bit position then this queue head is a candidate for transaction execution. If the EPS field indicates the endpoint is a high-speed endpoint, then the transaction executed is determined by the PID_Code field contained in the execution area. This field is also used to support split transaction types: Interrupt (IN/OUT). This condition is true when this field is non-zero and the EPS field indicates this is either a full- or low-speed device. A zero value in this field, in combination with existing in the periodic frame list has undefined results. |

## 17.5.6.3 Transfer overlay

The nine DWords in this area represent a transaction working space for the host controller.

The general operational model is that the host controller can detect whether the overlay area contains a description of an active transfer. If it does not contain an active transfer, then it follows the queue head horizontal link pointer to the next queue head. The host controller will never follow the next transfer queue element or alternate queue element pointers unless it is actively attempting to advance the queue. For the duration of the transfer, the host controller keeps the incremental status of the transfer in the overlay area. When the transfer is complete, the results are written back to the original queue element.

The DWord3 of a queue head contains a pointer to the source qTD currently associated with the overlay. The host controller uses this pointer to write back the overlay area into the source qTD after the transfer is complete.

The table below describes the current qTD link pointer.

Table 17-70. Current qTD link pointer

| Bits | Name | Description                                                                                                                                                                                                   |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 |      | Current element transaction descriptor link pointer. This field contains the address Of the current transaction being processed in this queue and corresponds to memory address signals [31:5], respectively. |
| 4-0  | -    | Reserved, should be cleared. These bits are ignored by the host controller when using the value as an address to write data. The actual value may vary depending on the usage.                                |

The DWords 4-11 of a queue head are the transaction overlay area. This area has the same base structure as a queue element transfer descriptor. The queue head utilizes the reserved fields of the page pointers to implement tracking the state of split transactions.

This area is characterized as an overlay because when the queue is advanced to the next queue element, the source queue element is merged onto this area. This area serves an execution cache for the transfer.

The table below describes the host-controller rules for bits in overlay.

Table 17-71. Host-controller rules for bits in overlay (DWords 5, 6, 8, and 9)

| DWor<br>d | QH<br>Offset | Bits  | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|--------------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5         | 0x14         | 4-1   | NakCnt      | Nak counter-RW. This field is a counter the host controller decrements whenever a transaction for the endpoint associated with this queue head results in a Nak or Nyet response. This counter is reloaded from RL before a transaction is executed during the first pass of the reclamation list (relative to an Asynchronous List Restart condition). It is also loaded from RL during an overlay. |
|           |              |       |             | Note that in host mode, the NAK counter is decremented after receiving a NYET to an OUT Token. Thus, the NAK counter may be lower than expected.                                                                                                                                                                                                                                                     |
| 6         | 0x18         | 31    | dt          | Data toggle. The Data toggle control controls whether the host controller preserves this bit when an overlay operation is performed.                                                                                                                                                                                                                                                                 |
| 6         | 0x18         | 15    | ioc         | Interrupt on complete. The ioc control bit is always inherited from the source qTD when the overlay operation is performed.                                                                                                                                                                                                                                                                          |
| 6         | 0x18         | 11-10 | Cerr        | Error counter. Copied from the qTD during the overlay and written back during queue advancement.                                                                                                                                                                                                                                                                                                     |
| 6         | 0x18         | 0     | Status[0]   | Ping state (P)/ERR. If the EPS field indicates a high-speed endpoint, then this field should be preserved during the overlay operation.                                                                                                                                                                                                                                                              |
| 8         | 0x20         | 7-0   | C-prog-mask | Split-transaction complete-split progress. Initialized to zero during any overlay. This field is used to track the progress of an interrupt split-transaction.                                                                                                                                                                                                                                       |
| 9         | 0x24         | 11-5  | S-bytes     | Software must ensure that the S-bytes field in a qTD is zero before activating the qTD. Keeps track of the number of bytes sent or received during an IN or OUT split transaction.                                                                                                                                                                                                                   |
| 9         | 0x24         | 4-0   | FrameTag    | Split-transaction frame tag. Initialized to zero during any overlay. This field is used to track the progress of an interrupt split-transaction.                                                                                                                                                                                                                                                     |

# 17.5.7 Periodic frame span traversal node (FSTN)

The periodic frame span traversal node (FSTN) data structure, shown in the table below, is to be used only for managing full- and low-speed transactions that span a host-frame boundary.

Software must not use an FSTN in the asynchronous schedule. An FSTN in the asynchronous schedule results in undefined behavior.

Table 17-72. Frame span traversal node structure

| 31  | 3                        | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1   | 1 | 15 | 1    | 1 | 1 | 1 | 1 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | offset |
|-----|--------------------------|---|---|---|---|---|---|---|---|---|---|---|---|-----|---|----|------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|
|     | 0                        | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7   | 6 |    | 4    | 3 | 2 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |        |
| Nor | Normal path link pointer |   |   |   |   |   |   |   |   |   |   | - |   | Тур | ) | Т  | 0x00 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |
| Bac | Back path link pointer   |   |   |   |   |   |   |   |   |   |   | - |   | Тур | ) | Т  | 0x04 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |

## NOTE

The host controller performs only read operations to the FSTN data structure.

# 17.5.7.1 FSTN normal path pointer

The first DWord of an FSTN contains a link pointer to the next schedule object.

This object can be of any valid periodic schedule data type. The table below describes the FSTN normal path pointer.

Table 17-73. FSTN normal path pointer

| Bits | Name | Description                                                                                                                                                                                        |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | NPLP | Normal path link pointer. Contains the address of the next data object to be processed in the periodic list and corresponds to memory address signals [31:5], respectively.                        |
| 4-3  | -    | Reserved, should be cleared. These bits must be written as 0s.                                                                                                                                     |
| 2-1  | Тур  | Indicates to the host controller whether the item referenced is a iTD/siTD, QH, or FSTN. This allows the host controller to perform the proper type of processing on the item after it is fetched. |
|      |      | 00 iTD (isochronous transfer descriptor)                                                                                                                                                           |
|      |      | 01 QH (queue head)                                                                                                                                                                                 |
|      |      | 10 siTD (split transaction isochronous transfer descriptor)                                                                                                                                        |
|      |      | 11 FSTN (frame span traversal node)                                                                                                                                                                |
| 0    | Т    | Terminate.                                                                                                                                                                                         |
|      |      | 0 Link pointer is valid.                                                                                                                                                                           |
|      |      | 1 Link pointer field is not valid.                                                                                                                                                                 |

## 17.5.7.2 FSTN back path link pointer

The second DWord of an FSTN node contains a link pointer to a queue head.

If the T-bit in this pointer is a zero, then this FSTN is a Save-Place indicator. Its Typ field must be set by software to indicate the target data structure is a queue head. If the T-bit in this pointer is set, then this FSTN is the Restore indicator. When the T-bit is a one, the host controller ignores the Typ field.

The table below describes the FSTN back path link pointer.

| Bits | Name | Description                                                                                                                                                                         |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | BPLP | Back path link pointer. Contains the address of a queue head. This field corresponds to memory address signals [31:5], respectively.                                                |
| 4-3  | -    | Reserved, should be cleared. These bits must be written as 0s.                                                                                                                      |
| 2-1  | Тур  | Software must ensure this field is set to indicate the target data structure is a Queue Head (01). Any other value in this field yields undefined results.                          |
| 0    | Т    | Terminate.  0 Link pointer is valid (that is, the host controller may use bits 31-5 as a valid memory address). This value also indicates that this FSTN is a Save-Place indicator. |
|      |      | 1 Link pointer field is not valid (that is, the host controller must not use bits 31-5 as a valid memory address). This value also indicates that this FSTN is a Restore indicator. |

Table 17-74. FSTN back path link pointer

# 17.6 Host operations

The general operational model for the USB DR module in host mode is defined by the Enhanced Host Controller Interface (EHCI) Specification. The EHCI specification describes the register-level interface for a host controller for the USB Revision 2.0. It includes a description of the hardware/software interface between system software and host controller hardware. Information concerning the initialization of the USB module is included in the following section; however, the full details of the EHCI specification are beyond the scope of this document.

## 17.6.1 Host controller initialization

After initial power-on or host controller reset (hardware or through USBCMD[RST]), all of the operational registers are at their default values.

To configure the external ULPI PHY the following initialization sequence is required:

- 1. The UTMI PHY should remain disabled if the ULPI is being used.
- 2. Set the CONTROL[PHY\_CLK\_SEL] bits to select the ULPI PHY as the source of USB controller PHY clock.
- 3. Wait for PHY clock to become valid. This can be determined by polling the CONTROL[PHY\_CLK\_VALID] status bit. Note that this bit is not valid once the CONTROL[USB\_EN] bit is set

Once the PHY clock is valid the user can proceed to the host controller initialization phase.

In order to initialize the USB DR module, software should perform the following steps:

1. Set the controller mode to host mode. Optionally set USBMODE[SDIS] (streaming disable)

## NOTE

Transitioning from device mode to host mode requires a host controller reset before modifying USBMODE.

- 2. Optionally modify the BURSTSIZE register.
- 3. Program the PTS field of the PORTSC register if using a non-ULPI PHY.
- 4. Set CONTROL[USB\_EN].
- 5. Write the appropriate value to the USBINTR register to enable the appropriate interrupts.
- 6. Write the base address of the periodic frame list to the PERIODICLIST BASE register. If there are no work items in the periodic schedule, all elements of the periodic frame list should have their T-Bits set.
- 7. Write the USBCMD register to set the desired interrupt threshold, frame list size (if applicable) and turn on the controller by setting the RS bit.

At this point, the USB DR module is up and running and the port registers begin reporting device connects. System software can enumerate a port through the reset process (where the port is in the enabled state). At this point, the port is active with SOFs occurring down the enabled high-speed ports, but the schedules have not yet been enabled. The EHCI host controller will not transmit SOFs to enabled Full- or Low-speed ports.

In order to communicate with devices via the asynchronous schedule, system software must write the ASYNDLISTADDR register with the address of a control or bulk queue head. Software must then enable the asynchronous schedule by writing a one to USBCMD[ASE]. In order to communicate with devices via the periodic schedule, system software must enable the periodic schedule by writing a one to USBCMD[PSE]. Note that the schedules can be turned on before the first port is reset (and enabled).

Any time the USBCMD register is written, system software must ensure the appropriate bits are preserved, depending on the intended operation.

## 17.6.2 Power port

The HCSPARAMS[PPC] bit indicates whether the USB 2.0 host controller has port power control.

When the PPC bit is set, the host controller supports port power switches. Each available switch has an output enable. PPE is controlled based on the state of the combination bits-PPC bit, EHCI Configured (CF)-bit and individual Port Power (PP) bit. The Configured Flag and Port Power Control bits are always 1'b1 in Host Mode. The PPE always follows the state of Port Power (PP) bit that is, if PP is 0, PPE will be 0 and if PP is 1, PPE will be 1.

# 17.6.3 Reporting over-current

Host ports by definition are power providers on USB.

Whether the ports are considered high- or low-powered is a platform implementation issue. The EHCI PORTSC register has an over-current status and over-current change bit. The functionality of these bits is specified in the USB Specification Revision 2.0.

The over current detection and limiting logic resides outside the DR logic. The overcurrent condition effects the following bits in the PORTSC register on the EHCI port:

- Over-current active bit (OCA) is set. When the over-current condition goes away, the OCA will transition from a one to a zero.
- Over-current change bit (OCC) is set. On every transition of OCA, the controller will set OCC to a one. Software sets OCC to a zero by writing a one to this bit.
- Port enabled/disabled bit (PE) is cleared. When this change bit gets set, USBSTS[PCI] (the port change detect bit) is set.
- Port power (PP) bit may optionally be cleared. There is no requirement in USB that a power provider shut off power in an over current condition. It is sufficient to limit the current and leave power applied. When OCC transitions from a zero to a one, the controller also sets USBSTS[PCI] to a one. In addition, if the Port Change Interrupt Enable bit, USBINTR[PCE], is a one, the controller issues an interrupt to the system. Refer to Table 17-75 for summary of behavior for over-current detection when the controller is halted (suspended from a device component point of view).

# 17.6.4 Suspend/resume

The host controller provides an equivalent suspend and resume model as that defined for individual ports in a USB 2.0 hub.

Control mechanisms are provided to allow system software to suspend and resume individual ports. The mechanisms allow the individual ports to be resumed completely through software initiation. Other control mechanisms are provided to parameterize the host controller's response (or sensitivity) to external resume events. In this discussion, host-initiated, or software-initiated resumes are called Resume Events/Actions; bus-initiated resume events are called wake-up events. The classes of wakeup events are:

- Remote-wakeup enabled device asserts resume signaling. In similar kind to USB 2.0 hubs, when in host mode the host controller responds to explicit device resume signaling and wake up the system (if necessary).
- Port connect and disconnect and over-current events. Sensitivity to these events can be turned on or off by using the port control bits in the PORTSC register.

Selective suspend is a feature supported by the PORTSC register. It is used to place specific ports into a suspend mode. This feature is used as a functional component for implementing the appropriate power management policy implemented in a particular operating system. When system software intends to suspend the bus, it should suspend the enabled port, then shut off the controller by setting the USBCMD[RS] to a zero.

When a wake event occurs the system will resume operation and system software must set the RS bit to a one and resume the suspended port.

## 17.6.4.1 Port suspend/resume

System software places the USB into suspend mode by writing a one into the appropriate PORTSC Suspend bit.

Software must only set the Suspend bit when the port is in the enabled state (Port Enabled bit is a one).

The host controller may evaluate the Suspend bit immediately or wait until a microframe or frame boundary occurs. If evaluated immediately, the port is not suspended until the current transaction (if one is executing) completes. Therefore, there may be several microframes of activity on the port until the host controller evaluates the Suspend bit. The host controller must evaluate the Suspend bit at least every frame boundary.

System software can initiate a resume on the suspended port by writing a one to PORTSC[FPR]. Software should not attempt to resume a port unless the port reports that it is in the suspended state. If system software sets PORTSC[FPR] when the port is not in

the suspended state, the resulting behavior is undefined. In order to assure proper USB device operation, software must wait for at least 10 milliseconds after a port indicates that it is suspended (Suspend bit is a one) before initiating a port resume through PORTSC[FPR]. When PORTSC[FPR] is set, the host controller sends resume signaling down the port. System software times the duration of the resume (nominally 20 milliseconds) then clears PORTSC[FPR]. When the host controller receives the write to transition PORTSC[FPR] to zero, it completes the resume sequence as defined in the USB specification, and clears both PORTSC[FPR] and PORTSC[SUSP]. Software-initiated port resumes do not affect the port change detect bit (USBSTS[PCI]) nor do they cause an interrupt if USBINTR[PCE] (port change interrupt enable) is a one. When a wake event occurs on a suspended port, the resume signaling is detected by the port and the resume is reflected downstream within 100 µsec. The port's PORTSC[FPR] bit is set and USBSTS[PCI] is set. If USBINTR[PCE] is a one, the host controller issues a hardware interrupt.

System software observes the resume event on the port, delays a port resume time (nominally 20 milliseconds), then terminates the resume sequence by clearing PORTSC[FPR] in the port. The host controller receives the write of zero to PORTSC[FPR], terminates the resume sequence and clears PORTSC[FPR] and PORTSC[SUSP]. Software can determine that the port is enabled (not suspended) by sampling the PORTSC register and observing that the SUSP and FPR bits are zero. Software must ensure that the host controller is running (that is, USBSTS[HCH] is a zero), before terminating a resume by clearing the port's PORTSC[FPR] bit. If HCH is a one when PORTSC[FPR] is cleared, then SOFs will not occur down the enabled port and the device will return to suspend mode in a maximum of 10 milliseconds.

The table below summarizes the wake-up events. Whenever a resume event is detected, USBSTS[PCI] is set. If USBINTR[PCE] (port change interrupt enable) is a one, the host controller also generates an interrupt on the resume event. Software acknowledges the resume event interrupt by clearing the USBSTS[PCI].

Table 17-75. Behavior during wake-up events

| Port status and signaling type                                                                             | Signaled port response                                                                                                                                                     | Device state |        |  |  |
|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|--|--|
|                                                                                                            |                                                                                                                                                                            | D0           | Not D0 |  |  |
| Port disabled, resume K-State received                                                                     | No effect                                                                                                                                                                  | N/A          | N/A    |  |  |
| Port suspended, Resume K-State received                                                                    | Resume reflected downstream on signaled port. PORTSC[FPR] is set. USBSTS[PCI] is set.                                                                                      | [1], [2]     | [2]    |  |  |
| Port is enabled, disabled or suspended, and the port's PORTSC[WKDS], is set. A disconnect is detected.     | Depending on the initial port state, the PORTSC Connect (CCS) and Enable (PE) status bits are cleared, and the Connect Change status bit (CSC) is set. USBSTS[PCI] is set. | [1], [2]     | [2]    |  |  |
| Port is enabled, disabled or suspended, and the port's PORTSC[WKDS], is cleared. A disconnect is detected. | Depending on the initial port state, the PORTSC Connect (CCS) and Enable (PE) status bits are cleared, and the Connect Change status bit (CSC) is set. USBSTS[PCI] is set. | [1], [3]     | [3]    |  |  |

Table 17-75. Behavior during wake-up events (continued)

| Port status and signaling type                                                                 | Signaled port response                                                                                                                                 | Device state |        |  |  |
|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|--|--|
|                                                                                                |                                                                                                                                                        | D0           | Not D0 |  |  |
| Port is not connected and the port's PORTSC[WKCN] bit is a one. A connect is detected.         | PORTSC Connect Status (CCS) and Connect Status Change (CSC) bits are set. USBSTS[PCI] is set.                                                          | [1], [2]     | [2]    |  |  |
| Port is not connected and the port's PORTSC[WKCN] bit is a zero. A connect is detected.        | PORTSC Connect Status (CCS) and Connect Status Change (CSC) bits are set. USBSTS[PCI] is set.                                                          | [1], [3]     | [3]    |  |  |
| Port is connected and the port's PORTSC[WKOC] bit is a one. An over-current condition occurs.  | PORTSC Over-current Active (OCA), Over-current Change (OCC) bits are set. If Port Enable/Disable bit (PE) is a one, it is cleared. USBSTS[PCI] is set  | [1], [2]     | [2]    |  |  |
| Port is connected and the port's PORTSC[WKOC] bit is a zero. An over-current condition occurs. | PORTSC Over-current Active (OCA), Over-current Change (OCC) bits are set. If Port Enable/Disable bit (PE) is a one, it is cleared. USBSTS[PCI] is set. | [1], [3]     | [3]    |  |  |

<sup>&</sup>lt;sup>1</sup> Hardware interrupt issued if USBINTR[PCE] (port change interrupt enable) is set.

## 17.6.5 Schedule traversal rules

The host controller executes transactions for devices using a simple, shared-memory schedule.

The schedule is comprised of a few data structures, organized into two distinct lists. The data structures are designed to provide the maximum flexibility required by USB, minimize memory traffic and hardware/software complexity.

System software maintains two schedules for the host controller: a periodic schedule and an asynchronous schedule. The root of the periodic schedule is the Periodic frame list base address [host mode] (USB\_PERIODICLISTBASE) register. The PERIODICLISTBASE register is the physical memory base address of the periodic frame list. The periodic frame list is an array of physical memory pointers. The objects referenced from the frame list must be valid schedule data structures as defined in Host data structures. In each microframe, if the periodic schedule is enabled (see Periodic schedule) then the host controller must execute from the periodic schedule before executing from the asynchronous schedule. It will only execute from the asynchronous schedule after it encounters the end of the periodic schedule. The host controller traverses the periodic schedule by constructing an array offset reference from the PERIODICLISTBASE and the FRINDEX registers (see the figure below). It fetches the element and begins traversing the graph of linked schedule data structures.

<sup>&</sup>lt;sup>2</sup> PME# asserted if enabled (Note: PME Status must always be set).

<sup>&</sup>lt;sup>3</sup> PME# not asserted.

The end of the periodic schedule is identified by a next link pointer of a schedule data structure having its T-bit set. When the host controller encounters a T-Bit set during a horizontal traversal of the periodic list, it interprets this as an End-Of-Periodic-List mark. This causes the host controller to cease working on the periodic schedule and transitions immediately to traversing the asynchronous schedule. Once this transition is made, the host controller executes from the asynchronous schedule until the end of the microframe.



Figure 17-44. Derivation of pointer into frame list array

When the host controller determines that it is time to execute from the asynchronous list, it uses the operational register ASYNCLISTADDR to access the asynchronous schedule, as shown in the figure below.



Figure 17-45. General format of asynchronous schedule list

The ASYNCLISTADDR register contains a physical memory pointer to the next queue head. When the host controller makes a transition to executing the asynchronous schedule, it begins by reading the queue head referenced by the ASYNCLISTADDR register. Software must set queue head horizontal pointer T-bits to a zero for queue heads in the asynchronous schedule.

# 17.6.6 Periodic schedule frame boundaries vs. bus frame boundaries

The USB Specification Revision 2.0 requires that the frame boundaries (SOF frame number changes) of the high-speed bus and the full- and low-speed bus(es) below USB 2.0 hubs be strictly aligned.

Super-imposed on this requirement is that USB 2.0 hubs manage full- and low-speed transactions via a microframe pipeline (see start- (SS) and complete- (CS) splits illustrated in the figure below). A simple, direct projection of the frame boundary model into the host controller interface schedule architecture creates tension (complexity for both hardware and software) between the frame boundaries and the scheduling mechanisms required to service the full- and low-speed transaction translator periodic pipelines.



Figure 17-46. Frame boundary relationship between HS bus and FS/LS bus

The simple projection, as the figure above illustrates, introduces frame-boundary wrap conditions for scheduling on both the beginning and end of a frame. In order to reduce the complexity for hardware and software, the host controller is required to implement a one microframe phase shift for its view of frame boundaries. The phase shift eliminates the beginning of frame and frame-wrap scheduling boundary conditions.

The implementation of this phase shift requires that the host controller use one register value for accessing the periodic frame list and another value for the frame number value included in the SOF token. These two values are separate, but tightly coupled. The periodic frame list is accessed via the Frame List Index Register (FRINDEX). Bits FRINDEX[2-0], represent the microframe number. The SOF value is coupled to the value of FRINDEX[13-3]. Both FRINDEX[13-3] and the SOF value are incremented based on FRINDEX[2-0]. It is required that the SOF value be delayed from the FRINDEX value by one microframe. The one microframe delay yields a host controller periodic schedule

and bus frame boundary relationship as illustrated in the figure below. This adjustment allows software to trivially schedule the periodic start and complete-split transactions for full-and low-speed periodic endpoints, using the natural alignment of the periodic schedule interface.

The figure below illustrates how periodic schedule data structures relate to schedule frame boundaries and bus frame boundaries. To aid the presentation, two terms are defined. The host controller's view of the 1-millisecond boundaries is called H-Frames. The high-speed bus's view of the 1-millisecond boundaries is called B-Frames.



Figure 17-47. Relationship of periodic schedule frame boundaries to bus frame boundaries

H-Frame boundaries for the host controller correspond to increments of FRINDEX[13-3]. Microframe numbers for the H-Frame are tracked by FRINDEX[2-0]. B-Frame boundaries are visible on the high-speed bus via changes in the SOF token's frame number. Microframe numbers on the high-speed bus are only derived from the SOF token's frame number (that is, the high-speed bus will see eight SOFs with the same frame number value). H-Frames and B-Frames have the fixed relationship (that is, B-Frames lag H-Frames by one microframe time) illustrated in the figure above. The host controller's periodic schedule is naturally aligned to H-Frames. Software schedules transactions for full- and low-speed periodic endpoints relative the H-Frames. The result is these transactions execute on the high-speed bus at exactly the right time for the USB 2.0 hub periodic pipeline. As described in USB frame index (USB\_FRINDEX), the SOF Value can be implemented as a shadow register (in this example, called SOFV), which lags the FRINDEX register bits [13-3] by one microframe count. The table below illustrates the required relationship between the value of FRINDEX and the value of

SOFV. This lag behavior can be accomplished by incrementing FRINDEX[13-3] based on carry-out on the 7 to 0 increment of FRINDEX[2-0] and incrementing SOFV based on the transition of 0 to 1 of FRINDEX[2-0].

Software is allowed to write to FRINDEX. USB frame index (USB\_FRINDEX), provides the requirements that software should adhere when writing a new value in FRINDEX.

|               | Current |              | Next          |      |              |  |  |  |  |
|---------------|---------|--------------|---------------|------|--------------|--|--|--|--|
| FRINDEX[13-3] | SOFV    | FRINDEX[2-0] | FRINDEX[13-3] | SOFV | FRINDEX[2-0] |  |  |  |  |
| N             | N       | 111          | N+1           | N    | 000          |  |  |  |  |
| N+1           | N       | 000          | N+1           | N+1  | 001          |  |  |  |  |
| N+1           | N+1     | 001          | N+1           | N+1  | 010          |  |  |  |  |
| N+1           | N+1     | 010          | N+1           | N+1  | 011          |  |  |  |  |
| N+1           | N+1     | 011          | N+1           | N+1  | 100          |  |  |  |  |
| N+1           | N+1     | 100          | N+1           | N+1  | 101          |  |  |  |  |
| N+1           | N+1     | 101          | N+1           | N+1  | 110          |  |  |  |  |
| N+1           | N+1     | 110          | N+1           | N+1  | 111          |  |  |  |  |

Table 17-76. Operation of FRINDEX and SOFV (SOF value register)

## 17.6.7 Periodic schedule

The periodic schedule traversal is enabled or disabled through USBCMD[PSE] (periodic schedule enable).

If USBCMD[PSE] is cleared, then the host controller simply does not try to access the periodic frame list via the PERIODICLISTBASE register. Likewise, when USBCMD[PSE] is a one, then the host controller does use the PERIODICLISTBASE register to traverse the periodic schedule. The host controller will not react to modifications to USBCMD[PSE] immediately. In order to eliminate conflicts with split transactions, the host controller evaluates USBCMD[PSE] only when FRINDEX[2-0] is zero. System software must not disable the periodic schedule if the schedule contains an active split transaction work item that spans the 0b000 microframe. These work items must be removed from the schedule before USBCMD[PSE] is cleared. USBSTS[PS] (periodic schedule status) indicates status of the periodic schedule. System software enables (or disables) the periodic schedule by setting (or clearing) USBCMD[PSE]. Software then can poll USBSTS[PS] to determine when the periodic schedule has made the desired transition. Software must not modify USBCMD[PSE] unless the value of USBCMD[PSE] equals that of USBSTS[PS].

The periodic schedule is used to manage all isochronous and interrupt transfer streams. The base of the periodic schedule is the periodic frame list. Software links schedule data structures to the periodic frame list to produce a graph of scheduled data structures. The graph represents an appropriate sequence of transactions on the USB. The figure below illustrates isochronous transfers (using iTDs and siTDs) with a period of one are linked directly to the periodic frame list. Interrupt transfers (are managed with queue heads) and isochronous streams with periods other than one are linked following the period-one iTD/siTDs. Interrupt queue heads are linked into the frame list ordered by poll rate. Longer poll rates are linked first (for example, closest to the periodic frame list), followed by shorter poll rates, with queue heads with a poll rate of one, on the very end.



Figure 17-48. Example periodic schedule

# 17.6.8 Managing isochronous transfers using iTDs

The structure of an iTD is presented in isochronous (high-speed) transfer descriptor (iTD).

There are four distinct sections to an iTD:

- Next link pointer
  - This is the first field.
  - This field is for schedule linkage purposes only.
- Transaction description array

- This is an eight-element array.
- Each element represents control and status information for one microframe's worth of transactions for a single high-speed isochronous endpoint.
- Buffer page pointer array
  - This is a 7-element array of physical memory pointers to data buffers.
  - These are 4K aligned pointers to physical memory.
- Endpoint capabilities
  - This area utilizes the unused low-order 12 bits of the buffer page pointer array.
  - Its fields are used across all transactions executed for this iTD, including endpoint addressing, transfer direction, maximum packet size and high-bandwidth multiplier.

## 17.6.8.1 Host controller operational model for iTDs

The host controller uses FRINDEX register bits 12-3 to index into the periodic frame list.

This means that the host controller visits each frame list element eight consecutive times before incrementing to the next periodic frame list element. Each iTD contains eight transaction descriptions, which map directly to FRINDEX register bits 2-0. Each iTD can span 8 microframes worth of transactions. When the host controller fetches an iTD, it uses FRINDEX register bits 2-0 to index into the transaction description array. When the first iTD in the periodic list is traversed after periodic schedule is enabled, the value of FRINDEX[2:0] may be other than 0, so the first transaction issued by the controller may be any of the eight available active transactions. If the active bit in the Status field of the indexed transaction description is cleared, the host controller ignores the iTD and follows the Next pointer to the next schedule data structure.

When the indexed active bit is a one the host controller continues to parse the iTD. It stores the indexed transaction description and the general endpoint information (device address, endpoint number, maximum packet size, and so on). It also uses the Page Select (PG) field to index the buffer pointer array, storing the selected buffer pointer and the next sequential buffer pointer. For example, if PG field is a 0, then the host controller will store Page 0 and Page 1.

The host controller constructs a physical data buffer address by concatenating the current buffer pointer (as selected using the current transaction description's PG field) and the transaction description's Transaction Offset field. The host controller uses the endpoint addressing information and I/O-bit to execute a transaction to the appropriate endpoint. When the transaction is complete, the host controller clears the active bit and writes back any additional status information to the Status field in the currently selected transaction description.

The data buffer associated with the iTD must be virtually contiguous memory. Seven page pointers are provided to support eight high-bandwidth transactions regardless of the starting packet's offset alignment into the first page. A starting buffer pointer (physical memory address) is constructed by concatenating the page pointer (example: page 0 pointer) selected by the active transaction descriptions' PG (example value: 0b00) field with the transaction offset field. As the transaction moves data, the host controller must detect when an increment of the current buffer pointer will cross a page boundary. When this occurs the host controller simply replaces the current buffer pointer's page portion with the next page pointer (example: page 1 pointer) and continues to move data. The size of each bus transaction is determined by the value in the Maximum Packet Size field. An iTD supports high-bandwidth pipes via the Mult (multiplier) field. When the Mult field is 1, 2, or 3, the host controller executes the specified number of Maximum Packet sized bus transactions for the endpoint in the current microframe. In other words, the Mult field represents a transaction count for the endpoint in the current microframe. If the Mult field is zero, the operation of the host controller is undefined. The transfer description is used to service all transactions indicated by the Mult field.

For OUT transfers, the value of the Transaction n Length field represents the total bytes to be sent during the microframe. The Mult field must be set by software to be consistent with Transaction n Length and Maximum Packet Size. The host controller will send the bytes in Maximum Packet Sized portions. After each transaction, the host controller decrements it's local copy of Transaction n Length by Maximum Packet Size. The number of bytes the host controller sends is always Maximum Packet Size or Transaction n Length, whichever is less. The host controller advances the transfer state in the transfer description, updates the appropriate record in the iTD and moves to the next schedule data structure. The maximum sized transaction supported is  $3 \times 1024$  bytes.

For IN transfers, the host controller issues Mult transactions. It is assumed that software has properly initialized the iTD to accommodate all possible data. During each IN transaction, the host controller must use Maximum Packet Size to detect packet babble errors. The host controller keeps the sum of bytes received in the Transaction *n* Length field.

After all transactions for the endpoint have completed for the microframe, Transaction n Length contains the total bytes received. The following actions can occur:

- If the final value of Transaction *n* Length is less than the value of Maximum Packet Size, less data was received than was allowed for from the associated endpoint. This short packet condition does not set USBSTS[UI] (USB interrupt). The host controller does not detect this condition.
- If the device sends more than Transaction *n* Length or Maximum Packet Size bytes (whichever is less), the host controller sets the Babble Detected bit and clears the

Active bit. Note, that the host controller does not update the iTD field Transaction n Length in this error scenario.

- If the Mult field is greater than one, the host controller automatically executes the value of Mult transactions. The host controller does not execute all Mult transactions in the following cases:
  - The endpoint is an OUT and Transaction *n* Length goes to zero before all the Mult transactions have executed (ran out of data).
  - The endpoint is an IN and the endpoint delivers a short packet, or an error occurs on a transaction before Mult transactions have been executed.

The end of microframe may occur before all of the transaction opportunities have been executed. When this happens, the transfer state of the transfer description is advanced to reflect the progress that was made; the result is written back to the iTD; and the host controller proceeds to processing the next microframe.

## 17.6.8.2 Software operational model for iTDs

A client buffer request to an isochronous endpoint may span 1 to N microframes.

When N is larger than one, system software may have to use multiple iTDs to read or write data with the buffer (if N is larger than eight, it must use more than one iTD).

The figure below illustrates the simple model of how a client buffer is mapped by system software to the periodic schedule (that is, the periodic frame list and a set of iTDs).



Figure 17-49. Example Association of iTDs to Client Request Buffer

On the right is the client description of its request. The description includes a buffer base address plus additional annotations to identify which portions of the buffer should be used with each bus transaction. In the middle is the iTD data structures used by the system software to service the client request. Each iTD can be initialized to service up to 24 transactions, organized into eight groups of up to three transactions each. Each group maps to one microframe's worth of transactions. The EHCI controller does not provide per transaction results within a microframe. It treats the per microframe transactions as a single logical transfer.

On the left is the host controller's frame list. System software establishes references from the appropriate locations in the frame list to each of the appropriate iTDs. If the buffer is large, system software can use a small set of iTDs to service the entire buffer. System software can activate the transaction description records (contained in each iTD) in any pattern required for the particular data stream.

As noted above, the client request includes a pointer to the base of the buffer and offsets into the buffer to annotate which buffer sections are to be used on each bus transaction that occurs on this endpoint. System software must initialize each transaction description in an iTD to ensure it uses the correct portion of the client buffer. For example, for each transaction description, the PG field is set to index the correct physical buffer page pointer and the Transaction Offset field is set relative to the correct buffer pointer page (for example, the same one referenced by the PG field). When the host controller executes a transaction it selects a transaction description record based on FRINDEX[2-0]. It then uses the current Page Buffer Pointer (as selected by the PG field) and concatenates to the transaction offset field. The result is a starting buffer address for the transaction. As the host controller moves data for the transaction, it must watch for a page wrap condition and properly advance to the next available Page Buffer Pointer. System software must not use the Page 6 buffer pointer in a transaction description where the length of the transfer will wrap a page boundary. Doing so yields undefined behavior. The host controller hardware is not required to alias the page selector to page zero. USB 2.0 isochronous endpoints can specify a period greater than one. Software can achieve the appropriate scheduling by linking iTDs into the appropriate frames (relative to the frame list) and by setting appropriate transaction description elements active bits to a one.

## 17.6.8.2.1 Periodic scheduling threshold

The isochronous scheduling threshold field in the HCCPARAMS capability register is an indicator to system software as to how the host controller pre-fetches and effectively caches schedule data structures.

It is used by system software when adding isochronous work items to the periodic schedule. The value of this field indicates to system software the minimum distance it can update isochronous data (relative to the current location of the host controller execution in the periodic list) and still have the host controller process them.

The iTD and siTD data structures each describe 8 microframes worth of transactions. The host controller is allowed to cache one (or more) of these data structures in order to reduce memory traffic. There are three basic caching models that account for the fact the isochronous data structures span 8 microframes. The three caching models are: no caching, microframe caching and frame caching.

When software is adding new isochronous transactions to the schedule, it always performs a read of the FRINDEX register to determine the current frame and microframe the host controller is currently executing. Of course, there is no information about where in the microframe the host controller is, so a constant uncertainty factor of one microframe has to be assumed. Combining the knowledge of where the host controller is executing with the knowledge of the caching model allows the definition of simple algorithms for how closely software can reliably work to the executing host controller.

No caching is indicated with a value of zero in the isochronous scheduling threshold field. The host controller may pre-fetch data structures during a periodic schedule traversal (per microframe) but will always dump any accumulated schedule state at the end of the microframe. At the appropriate time relative to the beginning of every microframe, the host controller always begins schedule traversal from the frame list. Software can use the value of the FRINDEX register (plus the constant 1 uncertainty-factor) to determine the approximate position of the executing host controller. When no caching is selected, software can add an isochronous transaction as near as 2 microframes in front of the current executing position of the host controller.

Frame caching is indicated with a non-zero value in bit [7] of the isochronous scheduling threshold field. In the frame-caching model, system software assumes that the host controller caches one (or more) isochronous data structures for an entire frame (8 microframes). Software uses the value of the FRINDEX register (plus the constant 1 uncertainty) to determine the current microframe/frame (assume modulo 8 arithmetic in adding the constant 1 to the microframe number). For any current frame N, if the current microframe is 0 to 6, then software can safely add isochronous transactions to Frame N + 1. If the current microframe is 7, then software can add isochronous transactions to Frame N + 2.

Microframe caching is indicated with a non-zero value in the least-significant 3 bits of the isochronous scheduling threshold field. System software assumes the host controller caches one or more periodic data structures for the number of microframes indicated in theisochronous scheduling threshold field. For example, if the count value were 2, then the host controller keeps a window of two microframes worth of state (current microframe, plus the next) on chip. On each microframe boundary, the host controller releases the current microframe state and begins accumulating the next microframe state.

# 17.6.9 Asynchronous schedule

The asynchronous schedule traversal is enabled or disabled through USBCMD[ASE] (asynchronous schedule enable).

If USBCMD[ASE] is cleared, then the host controller simply does not try to access the asynchronous schedule via the ASYNCLISTADDR register. Likewise, if USBCMD[ASE] is set, the host controller does use the ASYNCLISTADDR register to traverse the asynchronous schedule. Modifications to USBCMD[ASE] are not necessarily immediate. Rather the new value of the bit will only be taken into consideration the next time the host controller needs to use the value of the ASYNCLISTADDR register to get the next queue head.

USBSTS[AS] indicates status of the asynchronous schedule. System software enables (or disables) the asynchronous schedule by writing a one (or zero) to USBCMD[ASE]. Software then can poll USBSTS[AS] to determine when the asynchronous schedule has made the desired transition. Software must not modify USBCMD[ASE] unless the value of USBCMD[ASE] equals that of the USBSTS[AS] (asynchronous schedule status).

The asynchronous schedule is used to manage all Control and Bulk transfers. Control and Bulk transfers are managed using queue head data structures. The asynchronous schedule is based at the ASYNCLISTADDR register. The default value of the ASYNCLISTADDR register after reset is undefined and the schedule is disabled when USBCMD[ASE] is cleared.

Software may only write this register with defined results when the schedule is disabled, for example, USBCMD[ASE] and the USBSTS[AS] are cleared. System software enables execution from the asynchronous schedule by writing a valid memory address (of a queue head) into this register. Then software enables the asynchronous schedule by setting USBCMD[ASE]. The asynchronous schedule is actually enabled when USBSTS[AS] is set.

When the host controller begins servicing the asynchronous schedule, it begins by using the value of the ASYNCLISTADDR register. It reads the first referenced data structure and begins executing transactions and traversing the linked list as appropriate. When the host controller completes processing the asynchronous schedule, it retains the value of the last accessed queue head's horizontal pointer in the ASYNCLISTADDR register. Next time the asynchronous schedule is accessed, this is the first data structure that is serviced. This provides round-robin fairness for processing the asynchronous schedule.

A host controller completes processing the asynchronous schedule when one of the following events occur:

- The end of a microframe occurs.
- The host controller detects an empty list condition
- The schedule has been disabled through USBCMD[ASE].

The queue heads in the asynchronous list are linked into a simple circular list as shown in Figure 17-45. Queue head data structures are the only valid data structures that may be linked into the asynchronous schedule. An isochronous transfer descriptor (iTD or siTD) in the asynchronous schedule yields undefined results.

The maximum packet size field in a queue head is sized to accommodate the use of this data structure for all non-isochronous transfer types. The USB Specification, Revision 2.0 specifies the maximum packet sizes for all transfer types and transfer speeds. System software should always parameterize the queue head data structures according to the core specification requirements.

## 17.6.9.1 Adding queue heads to asynchronous schedule

This is a software requirement section. There are two independent events for adding queue heads to the asynchronous schedule.

The first is the initial activation of the asynchronous list. The second is inserting a new queue head into an activated asynchronous list.

Activation of the list is simple. System software writes the physical memory address of a queue head into the ASYNCLISTADDR register, then enables the list by setting USBCMD[ASE] to a one.

When inserting a queue head into an active list, software must ensure that the schedule is always coherent from the host controllers' point of view. This means that the system software must ensure that all queue head pointer fields are valid. For example qTD pointers have T-Bits set or reference valid qTDs and the Horizontal Pointer references a valid queue head data structure. The following algorithm represents the functional requirements:

```
InsertQueueHead (pQHeadCurrent, pQueueHeadNew)
--
-- Requirement: all inputs must be properly initialized.
--
-- pQHeadCurrent is a pointer to a queue head that is
-- already in the active list
-- pQHeadNew is a pointer to the queue head to be added
--
-- This algorithm links a new queue head into a existing
-- list
--
pQueueHeadNew.HorizontalPointer = pQueueHeadCurrent.HorizontalPointer
pQueueHeadCurrent.HorizontalPointer = physicalAddressOf(pQueueHeadNew)
End InsertOueueHead
```

# 17.6.9.2 Removing queue heads from asynchronous schedule

This is a software requirement section.

There are two independent events for removing queue heads from the asynchronous schedule.

The first is shutting down (deactivating) the asynchronous list. The second is extracting a single queue head from an activated list. Software deactivates the asynchronous schedule by setting USBCMD[ASE] to a zero. Software can determine when the list is idle when USBSTS[AS] is cleared. The normal mode of operation is that software removes queue heads from the asynchronous schedule without shutting it down. Software must not remove an active queue head from the schedule. Software should first deactivate all active qTDs, wait for the queue head to go inactive, then remove the queue head from the asynchronous list. Software removes a queue head from the asynchronous list using the following algorithm. Software merely must ensure all of the link pointers reachable by the host controller are kept consistent.

```
UnlinkQueueHead (pQHeadPrevious, pQueueHeadToUnlink, pQHeadNext)
-- Requirement: all inputs must be properly initialized.
-- pQHeadPrevious is a pointer to a queue head that
-- references the queue head to remove
-- pQHeadToUnlink is a pointer to the queue head to be
-- removed
-- pQheadNext is a pointer to a queue head still in the
-- schedule. Software provides this pointer with the
-- following strict rules:
-- if the host software is one queue head, then
-- pQHeadNext must be the same as
  QueueheadToUnlink.HorizontalPointer. If the host
  software is unlinking a consecutive series of
-- queue heads, QHeadNext must be set by software to
-- the queue head remaining in the schedule.
-- This algorithm unlinks a queue head from a circular list
pQueueHeadPrevious.HorizontalPointer = pQueueHeadToUnlink.HorizontalPointer
pQueueHeadToUnlink.HorizontalPointer = pQHeadNext
End UnlinkQueueHead
```

If software removes the queue head with the H-bit set, it must select another queue head still linked into the schedule and set its H-bit. This should be completed before removing the queue head. The requirement is that software keep one queue head in the asynchronous schedule, with its H-bit set. At the point software has removed one or more queue heads from the asynchronous schedule, it is unknown whether the host controller

has a cached pointer to them. Similarly, it is unknown how long the host controller might retain the cached information, as it is implementation dependent and may be affected by the actual dynamics of the schedule load. Therefore, once software has removed a queue head from the asynchronous list, it must retain the coherency of the queue head (link pointers). It cannot disturb the removed queue heads until it knows that the host controller does not have a local copy of a pointer to any of the removed data structures.

The method software uses to determine when it is safe to modify a removed queue head is to handshake with the host controller. The handshake mechanism allows software to remove items from the asynchronous schedule, then execute a simple, lightweight handshake that is used by software as a key that it can free (or reuse) the memory associated the data structures it has removed from the asynchronous schedule.

The handshake is implemented with three bits in the host controller. The first bit is a command bit (USBCMD[IAA]-interrupt on async advance doorbell) that allows software to inform the host controller that something has been removed from its asynchronous schedule. The second bit is a status bit (USBSTS[AAI]-interrupt on async advance) that the host controller sets after it has released all on-chip state that may potentially reference one of the data structures just removed. When the host controller sets this status bit, it also clears the command bit. The third bit is an interrupt enable (USBINTR[AAE]-interrupt on async advance enable) that is matched with the status bit. If the status bit is set and the interrupt enable bit is set, then the host controller asserts a hardware interrupt.

The figure below illustrates a general example where consecutive queue heads (B and C) are unlinked from the schedule using the algorithm above. Before the unlink operation, the host controller has a copy of queue head A.

The unlink algorithm requires that as software unlinks each queue head, the unlinked queue head is loaded with the address of a queue head that will remain in the asynchronous schedule.

When the host controller observes that doorbell bit being set, it makes a note of the local reachable schedule information. In this example, the local reachable schedule information includes both queue heads (A & B). It is sufficient that the host controller can set the status bit (and clear the doorbell bit) as soon as it has traversed beyond current reachable schedule information (that is, traversed beyond queue head (B) in this example).



Figure 17-50. Generic queue head unlink scenario

Alternatively, a host controller implementation is allowed to traverse the entire asynchronous schedule list (for example, observed the head of the queue (twice)) before setting USBSTS[AAI].

Software may re-use the memory associated with the removed queue heads after it observes USBSTS[AAI] is set, following assertion of the doorbell. Software should acknowledge the interrupt on async advance status as indicated in the USBSTS register, before using the doorbell handshake again

## 17.6.9.3 Empty asynchronous schedule detection

EHCI uses two bits to detect when the asynchronous schedule is empty.

The queue head data structure (see Table 17-66) defines an H-bit in the queue head, which allows software to mark a queue head as being the head of the reclaim list. Host controller also keeps a 1-bit flag in the USBSTS register (Reclamation) that is cleared when the host controller observes a queue head with the H-bit set. The reclamation flag in the status register is set when any USB transaction from the asynchronous schedule is executed (or whenever the asynchronous schedule starts, see Asynchronous schedule traversal: Start event.

If the controller ever encounters an H-bit of one and a Reclamation bit of zero, the controller simply stops traversal of the asynchronous schedule.

The figure below shows an example illustrating the H-bit in a schedule.



Figure 17-51. Asynchronous schedule list with annotation to mark head of list

## 17.6.9.4 Asynchronous schedule traversal: Start event

Once the host controller has idled itself using the empty schedule detection, it naturally activates and begins processing from the Periodic Schedule at the beginning of each microframe.

In addition, it may have idled itself early in a microframe. When this occurs (idles early in the microframe) the host controller must occasionally reactivate during the microframe and traverse the asynchronous schedule to determine whether any progress can be made. Asynchronous schedule Start Events are defined to be:

- Whenever the host controller transitions from the periodic schedule to the asynchronous schedule. If the periodic schedule is disabled and the asynchronous schedule is enabled, then the beginning of the microframe is equivalent to the transition from the periodic schedule, or
- The asynchronous schedule traversal restarts from a sleeping state.

## 17.6.9.5 Reclamation status bit (USBSTS Register)

The operation of the empty asynchronous schedule detection feature depends on the proper management of the Reclamation bit (RCL) in the USBSTS register.

The host controller tests for an empty schedule just after it fetches a new queue head while traversing the asynchronous schedule. The host controller sets USBSTS[RCL] whenever an asynchronous schedule traversal Start Event occurs. USBSTS[RCL] is also set whenever the host controller executes a transaction while traversing the asynchronous schedule. The host controller clears USBSTS[RCL] whenever it finds a queue head with its H-bit set. Software should only set a queue head's H-bit if the queue head is in the asynchronous schedule. If software sets the H-bit in an interrupt queue head, the resulting behavior is undefined. The host controller may clear USBSTS[RCL] when executing from the periodic schedule.

# 17.6.10 Managing control/bulk/interrupt transfers via queue heads

This section presents an overview of how the host controller interacts with queuing data structures.

Queue heads use the Queue Element Transfer Descriptor (qTD) structure defined in Queue element transfer descriptor (qTD).

One queue head is used to manage the data stream for one endpoint. The queue head structure contains static endpoint characteristics and capabilities. It also contains a working area from where individual bus transactions for an endpoint are executed. Each qTD represents one or more bus transactions, which is defined in the context of the EHCI specification as a transfer.

The general processing model for the host controller's use of a queue head is simple:

- Read a queue head,
- Execute a transaction from the overlay area,
- Write back the results of the transaction to the overlay area
- Move to the next queue head.

If the host controller encounters errors during a transaction, the host controller will set one of the error reporting bits in the queue head's Status field. The Status field accumulates all errors encountered during the execution of a qTD (that is, the error bits in the queue head Status field are sticky until the transfer (qTD) has completed). This state is always written back to the source qTD when the transfer is complete. On transfer (for example, buffer or halt conditions) boundaries, the host controller must auto-advance (without software intervention) to the next qTD. Additionally, the hardware must be able to halt the queue so no additional bus transactions will occur for the endpoint and the host controller will not advance the queue.

## 17.6.10.1 Buffer pointer list use for data streaming with qTDs

A qTD has an array of buffer pointers, which is used to reference the data buffer for a transfer.

The EHCI specification requires that the buffer associated with the transfer be virtually contiguous. This means that if the buffer spans more than one physical page, it must obey the following rules:

- The first portion of the buffer must begin at some offset in a page and extend through the end of the page.
- The remaining buffer cannot be allocated in small chunks scattered around memory. For each 4K chunk beyond the first page, each buffer portion matches to a full 4K page. The final portion, which may only be large enough to occupy a portion of a page, must start at the top of the page and be contiguous within that page.

The figure below illustrates these requirements.



Figure 17-52. Example mapping of qTD buffer pointers to buffer pages

The buffer pointer list in the qTD is long enough to support a maximum transfer size of 20K bytes. This case occurs when all five buffer pointers are used and the first offset is zero. A qTD handles a 16Kbyte buffer with any starting buffer alignment.

The host controller uses the C\_Page field as an index value to determine which buffer pointer in the list should be used to start the current transaction. The host controller uses a different buffer pointer for each physical page of the buffer. This is always true, even if the buffer is physically contiguous.

The host controller must detect when the current transaction spans a page boundary and automatically move to the next available buffer pointer in the page pointer list. The next available pointer is reached by incrementing C\_Page and pulling the next page pointer from the list. Software must ensure there are sufficient buffer pointers to move the amount of data specified in the Bytes to Transfer field.

The figure above illustrates a nominal example of how System software would initialize the buffer pointers list and the C\_Page field for a transfer size of 16383 bytes. C\_Page is cleared. The upper 20-bits of Page 0 references the start of the physical page. Current Offset (the lower 12-bits of queue head Dword 7) holds the offset in the page for example, 2049 (for example, 4096-2047). The remaining page pointers are set to reference the beginning of each subsequent 4K page.

For the first transaction on the qTD (assuming a 512-byte transaction), the host controller uses the first buffer pointer (page 0 because C\_Page is cleared) and concatenates the Current Offset field. The 512 bytes are moved during the transaction, the Current Offset and Total Bytes to Transfer are adjusted by 512 and written back to the queue head working area.

During the 4th transaction, the host controller needs 511 bytes in page 0 and one byte in page 1. The host controller will increment C\_Page (to 1) and use the page 1 pointer to move the final byte of the transaction. After the 4th transaction, the active page pointer is the page 1 pointer and Current Offset has rolled to one, and both are written back to the overlay area. The transactions continue for the rest of the buffer, with the host controller automatically moving to the next page pointer (that is, C\_Page) when necessary. There are three conditions for how the host controller handles C\_Page.

- The current transaction does not span a page boundary. The value of C\_Page is not adjusted by the host controller.
- The current transaction does span a page boundary. The host controller must detect the page cross condition and advance to the next buffer while streaming data to/from the USB.
- The current transaction completes on a page boundary (that is, the last byte moved for the current transaction is the last byte in the page for the current page pointer). The host controller must increment C\_Page before writing back status for the transaction.

Note that the only valid adjustment the host controller may make to C\_Page is to increment by one.

# 17.6.10.2 Adding interrupt queue heads to the periodic schedule

The link path(s) from the periodic frame list to a queue head establishes in which frames a transaction can be executed for the queue head.

Queue heads are linked into the periodic schedule so they are polled at the appropriate rate. System software sets a bit in a queue head's S-Mask to indicate which microframe within a 1 millisecond period a transaction should be executed for the queue head. Software must ensure that all queue heads in the periodic schedule have S-Mask set to a non-zero value. An S-mask with a zero value in the context of the periodic schedule yields undefined results.

If the desired poll rate is greater than one frame, system software can use a combination of queue head linking and S-Mask values to spread interrupts of equal poll rates through the schedule so that the periodic bandwidth is allocated and managed in the most efficient manner possible. Some examples are illustrated in the table below.

Table 17-77. Example periodic reference patterns for interrupt transfers

| Frame # reference sequence       | Description                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0, 2, 4, 6, 8, S-<br>Mask = 0x01 | A queue head for the bInterval of 2 milliseconds (16 microframes) is linked into the periodic schedule so that it is reachable from the periodic frame list locations indicated in the previous column. In addition, the S-Mask field in the queue head is set to 0x01, indicating that the transaction for the endpoint should be executed on the bus during microframe 0 of the frame. |
| 0, 2, 4, 6, 8, S-<br>Mask = 0x02 | Another example of a queue head with a bInterval of 2 milliseconds is linked into the periodic frame list at exactly the same interval as the previous example. However, the S-Mask is set to 0x02 indicating that the transaction for the endpoint should be executed on the bus during microframe 1 of the frame.                                                                      |

# 17.6.10.3 Managing transfer complete interrupts from queue heads

The host controller sets an interrupt to be signaled at the next interrupt threshold when the completed transfer (qTD) has an Interrupt on Complete (IOC) bit set, or whenever a transfer (qTD) completes with a short packet.

If system software needs multiple qTDs to complete a client request (that is, like a control transfer) the intermediate qTDs do not require interrupts. System software may only need a single interrupt to notify it that the complete buffer has been transferred. System software may set IOC's to occur more frequently. A motivation for this may be that it wants early notification so that interface data structures can be re-used in a timely manner.

# 17.6.11 Ping control

USB 2.0 defines an addition to the protocol for high-speed devices called Ping.

Ping is required for all USB 2.0 High-speed bulk and control endpoints. Ping is not allowed for a split-transaction stream. This extension to the protocol eliminates the bad side-effects of Naking OUT endpoints. The Status field has a Ping State bit, which the host controller uses to determine the next actual PID it will use in the next transaction to the endpoint (see Table 17-64). The Ping State bit is only managed by the host controller for queue heads that meet all of the following criteria:

- The queue head is not an interrupt
- The EPS field equals High-Speed
- The PIDCode field equals OUT

The table below illustrates the state transition table for the host controller's responsibility for maintaining the PING protocol. Refer to Chapter 8 in the *USB Specification, Revision 2.0* for detailed description on the Ping protocol.

|         | Ev   |                      |                      |
|---------|------|----------------------|----------------------|
| Current | Host | Device               | Next                 |
| Do Ping | PING | Nak                  | Do Ping              |
| Do Ping | PING | Ack                  | Do OUT               |
| Do Ping | PING | XactErr <sup>1</sup> | Do Ping              |
| Do Ping | PING | Stall                | N/C <sup>2</sup>     |
| Do OUT  | OUT  | Nak                  | Do Ping              |
| Do OUT  | OUT  | Nyet                 | Do Ping <sup>3</sup> |
| Do OUT  | OUT  | Ack                  | Do OUT               |
| Do OUT  | OUT  | XactErr <sup>1</sup> | Do Ping              |
| Do OUT  | OUT  | Stall                | N/C <sup>2</sup>     |

Table 17-78. Ping control state transition table

- 1. Transaction Error (XactErr) is any time the host misses the handshake.
- 2. No transition change required for the Ping State bit. The Stall handshake results in the endpoint being halted (for example, Active cleared and Halt set). Software intervention is required to restart queue.
- 3. A Nyet response to an OUT means that the device has accepted the data, but cannot receive any more at this time. Host must advance the transfer state and additionally, transition the Ping State bit to Do Ping.

The Ping State bit is described in Table 17-64. The defined ping protocol allows the host to be imprecise on the initialization of the ping protocol (that is, start in Do OUT when there is uncertainty about the space in the device). The host controller manages the Ping State bit. System software sets the initial value in the queue head when it initializes a

queue head. The host controller preserves the Ping State bit across all queue advancements. This means that when a new qTD is written into the queue head overlay area, the previous value of the Ping State bit is preserved.

#### NOTE

For high-speed bulk and control endpoints, a host controller queries the high-speed device endpoint with a special ping token to determine whether the device has sufficient space for the next OUT transaction. The mechanism avoids using bus time to send data until the host controller knows that the endpoint has space for the data. If a timeout occurs after the data phase of an OUT transaction, the host controller fails to enter the ping state and instead retries the OUT token again.

The Ping flow control for the high-speed devices does not work under this condition. Therefore, some USB bandwidth could be wasted. However, NAK response to PING token or timeout is expected to be an unusual occurrence. A high-speed bulk/ control endpoint must specify its maximum NAK rate in its endpoint descriptor. The endpoint is allowed to NAK at most one time each micro-frame period.

# 17.6.12 Split transactions

USB 2.0 defines extensions to the bus protocol for managing USB 1.x data streams through USB 2.0 hubs. This section describes how the host controller uses the interface data structures to manage data streams with full- and low-speed devices, connected below a USB 2.0 hub, utilizing the split transaction protocol. Refer to the USB 2.0 Specification for the complete definition of the split transaction protocol.

Full- and low-speed devices are enumerated identically as high-speed devices, but the transactions to the full- and low-speed endpoints use the split-transaction protocol on the high-speed bus.

The split transaction protocol is an encapsulation of (or wrapper around) the full- or low-speed transaction. The high-speed wrapper portion of the protocol is addressed to the USB 2.0 hub and transaction translator below which the full- or low-speed device is attached.

EHCI uses dedicated data structures for managing full-speed isochronous data streams. Control, Bulk and Interrupt are managed using the queuing data structures. The interface data structures need to be programmed with the device address and the transaction

translator number of the USB 2.0 hub operating as the low-/full-speed host controller for this link. The following sections describe the details of how the host controller processes and manages the split transaction protocol.

# 17.6.12.1 Split transactions for asynchronous transfers

A queue head in the asynchronous schedule with an EPS field indicating a full-or low-speed device indicates to the host controller that it must use split transactions to stream data for this queue head.

All full-speed bulk and full-, low-speed control are managed via queue heads in the asynchronous schedule.

Software must initialize the queue head with the appropriate device address and port number for the transaction translator that is serving as the full-/low-speed host controller for the links connecting the endpoint. Software must also initialize the split transaction state bit (SplitXState) to Do-Start-Split. Finally, if the endpoint is a control endpoint, then system software must set the Control Transfer Type (C) bit in the queue head to a one. If this is not a control transfer type endpoint, the C bit must be initialized by software to be a zero. This information is used by the host controller to properly set the Endpoint Type (ET) field in the split transaction bus token. When the C bit is a zero, the split transaction token's ET field is set to indicate a bulk endpoint. When the C bit is a one, the split transaction token's ET field is set to indicate a control endpoint. Refer to Chapter 8 of USB Specification, Revision 2.0 for details.



Figure 17-53. Host controller asynchronous schedule split-transaction state machine

## 17.6.12.1.1 Asynchronous-do-start-split

Do-start-split is the state which software must initialize a full- or low-speed asynchronous queue head.

This state is entered from the Do-Complete-Split state only after a complete-split transaction receives a valid response from the transaction translator that is not a Nyet handshake.

For queue heads in this state, the host controller executes a start-split transaction to the transaction translator. If the bus transaction completes without an error and PID Code indicates an IN or OUT transaction, then the host controller reloads the error counter (Cerr). If it is a successful bus transaction and the PID Code indicates a SETUP, the host controller will not reload the error counter. If the transaction translator responds with a Nak, the queue head is left in this state, and the host controller proceeds to the next queue head in the asynchronous schedule.

If the host controller times out the transaction (no response, or bad response) the host controller decrements Cerr and proceeds to the next queue head in the asynchronous schedule.

## 17.6.12.1.2 Asynchronous-do-complete-split

This state is entered from the Do-Start-Split state only after a start-split transaction receives an Ack handshake from the transaction translator.

For queue heads in this state, the host controller executes a complete-split transaction to the transaction translator. If the transaction translator responds with a Nyet handshake, the queue head is left in this state, the error counter is reset and the host controller proceeds to the next queue head in the asynchronous schedule. When a Nyet handshake is received for a bus transaction where the queue head's PID Code indicates an IN or OUT, the host controller reloads the error counter (Cerr). When a Nyet handshake is received for a complete-split bus transaction where the queue head's PID Code indicates a SETUP, the host controller must not adjust the value of Cerr.

Independent of PID Code, the following responses have the indicated effects:

• Transaction Error (XactErr). Timeout/data CRC failure. The error counter (Cerr) is decremented by one and the complete split transaction is immediately retried (if possible). If there is not enough time in the microframe to execute the retry, the host controller ensures that the next time the host controller begins executing from the Asynchronous schedule, it must begin executing from this queue head. If another start-split (for some other endpoint) is sent to the transaction translator before the complete-split is really completed, the transaction translator could dump the results (which were never delivered to the host). This is why the core specification states the

- retries must be immediate. When the host controller returns to the asynchronous schedule in the next microframe, the first transaction from the schedule will be the retry for this endpoint. If Cerr went to zero, the host controller halts the queue.
- NAK. The target endpoint Nak'd the full- or low-speed transaction. The state of the transfer is not advanced and the state is exited. If the PID Code is a SETUP, then the Nak response is a protocol error. The XactErr status bit is set and the Cerr field is decremented.
- STALL. The target endpoint responded with a STALL handshake. The host controller sets the halt bit in the status byte, retires the qTD but does not attempt to advance the queue.

If the PID Code indicates an IN, then any of following responses are expected:

• DATA0/1. On reception of data, the host controller ensures the PID matches the expected data toggle and checks CRC. If the packet is good, the host controller advances the state of the transfer (for example, moves the data pointer by the number of bytes received, decrements the BytesToTransfer field by the number of bytes received, and toggles the dt bit). The host controller then exits this state. The response and advancement of transfer may trigger other processing events, such as retirement of the qTD and advancement of the queue.

If the data sequence PID does not match the expected, the data is ignored, the transfer state is not advanced and this state is exited.

If the PID Code indicates an OUT/SETUP, then any of following responses are expected:

• ACK. The target endpoint accepted the data, so the host controller must advance the state of the transfer. The Current Offset field is incremented by Maximum Packet Length or Bytes to Transfer, whichever is less. The Bytes To Transfer field is decremented by the same amount and the data toggle bit (dt) is toggled. The host controller then exits this state.

Advancing the transfer state may cause other processing events such as retirement of the qTD and advancement of the queue.

## 17.6.12.2 Split transaction interrupt

Split-transaction interrupt-IN/OUT endpoints are managed using the same data structures used for high-speed interrupt endpoints.

They both co-exist in the periodic schedule. Queue heads/qTDs offer the set of features required for reliable data delivery, which is characteristic to interrupt transfer types. The split-transaction protocol is managed completely within this defined functional transfer

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

framework. For example, for a high-speed endpoint, the host controller will visit a queue head, execute a high-speed transaction (if criteria are met) and advance the transfer state (or not) depending on the results of the entire transaction. For low- and full-speed endpoints, the details of the execution phase are different (that is, takes more than one bus transaction to complete), but the remainder of the operational framework is intact.

## 17.6.12.2.1 Split transaction scheduling mechanisms for interrupt

Full- and low-speed interrupt queue heads have an EPS field indicating full- or low-speed and have a non-zero S-mask field.

The host controller can detect this combination of parameters and assume the endpoint is a periodic endpoint. Low- and full-speed interrupt queue heads require the use of the split transaction protocol. The host controller sets the Endpoint Type (ET) field in the split token to indicate the transaction is an interrupt. These transactions are managed through a transaction translator's periodic pipeline. Software should not set these fields to indicate the queue head is an interrupt unless the queue head is used in the periodic schedule.

System software manages the per/transaction translator periodic pipeline by budgeting and scheduling exactly during which microframes the start-splits and complete-splits for each endpoint will occur. The characteristics of the transaction translator are such that the high-speed transaction protocol must execute during explicit microframes, or the data or response information in the pipeline is lost. The figure below illustrates the general scheduling boundary conditions that are supported by the EHCI periodic schedule and queue head data structure. The S and  $C_n$  labels indicate microframes where software can schedule start-splits and complete splits (respectively).



Figure 17-54. Split transaction, interrupt scheduling boundary conditions

The scheduling cases are:

- Case 1: The normal scheduling case is where the entire split transaction is completely bounded by a frame (H-Frame in this case).
- Case 2a through Case 2c: The USB 2.0 hub pipeline rules states clearly, when and how many complete-splits must be scheduled to account for earliest to latest execution on the full/low-speed link. The complete-splits may span the H-Frame boundary when the start-split is in microframe 4 or later. When this occurs, the H-Frame to B-Frame alignment requires that the queue head be reachable from consecutive periodic frame list locations. System software cannot build an efficient schedule that satisfies this requirement unless it uses FSTNs.

The figure below illustrates the general layout of the periodic schedule.



Figure 17-55. General structure of EHCI periodic schedule utilizing interrupt spreading

The periodic frame list is effectively the leaf level a binary tree, which is always traversed leaf to root. Each level in the tree corresponds to a 2<sup>N</sup> poll rate. Software can efficiently manage periodic bandwidth on the USB by spreading interrupt queue heads that have the same poll rate requirement across all the available paths from the frame list. For example, system software can schedule eight poll rate 8 queue heads and account for them once in the high-speed bus bandwidth allocation.

When an endpoint is allocated an execution footprint that spans a frame boundary, the queue head for the endpoint must be reachable from consecutive locations in the frame list. An example would be if  $8_{0b}$  were such an endpoint. Without additional support on the interface, to get  $8_{0b}$  reachable at the correct time, software would have to link  $8_1$  to  $8_{0b}$ . It would then have to move  $4_1$  and everything linked after into the same path as  $4_0$ . This upsets the integrity of the binary tree and disallows the use of the spreading technique.

FSTN data structures are used to preserve the integrity of the binary-tree structure and enable the use of the spreading technique. Periodic frame span traversal node (FSTN), defines the hardware and software operational model requirements for using FSTNs.

The following queue head fields are initialized by system software to instruct the host controller when to execute portions of the split-transaction protocol.

• SplitXState. This is a single bit residing in the Status field of a queue head (Table 17-64). This bit is used to track the current state of the split transaction.

- Frame S-mask. This is a bit-field where-in system software sets a bit corresponding to the microframe (within an H-Frame) that the host controller should execute a start-split transaction. This is always qualified by the value of the SplitXState bit in the Status field of the queue head. For example, referring to Figure 17-54, case one, the S-mask would have a value of 0b0000\_0001 indicating that if the queue head is traversed by the host controller, and the SplitXState indicates Do\_Start, and the current microframe as indicated by FRINDEX[2-0] is 0, then execute a start-split transaction.
- Frame C-mask. This is a bit-field where system software sets one or more bits corresponding to the microframes (within an H-Frame) that the host controller should execute complete-split transactions. The interpretation of this field is always qualified by the value of the SplitXState bit in the Status field of the queue head. For example, referring to Figure 17-54, case one, the C-mask would have a value of 0b0001\_1100 indicating that if the queue head is traversed by the host controller, and the SplitXState indicates Do\_Complete, and the current microframe as indicated by FRINDEX[2-0] is 2, 3, or 4, then execute a complete-split transaction. It is software's responsibility to ensure that the translation between H-Frames and B-Frames is correctly performed when setting bits in S-mask and C-mask.

## 17.6.12.2.2 Host controller operational model for FSTNs

The FSTN data structure is used to manage Low/Full-speed interrupt queue heads that need to be reached from consecutive frame list locations (that is, boundary cases 2a through 2c).

An FSTN is essentially a back pointer, similar in intent to the back pointer field in the siTD data structure.

This feature provides software a simple primitive to save a schedule position, redirect the host controller to traverse the necessary queue heads in the previous frame, then restore the original schedule position and complete normal traversal.

There are four components to the use of FSTNs:

- FSTN data structure, defined in Periodic frame span traversal node (FSTN).
- A Save Place indicator; this is always an FSTN with its Back Path Link Pointer[T] bit cleared.
- A Restore indicator; this is always an FSTN with its Back Path Link Pointer[T] bit set.
- Host controller FSTN traversal rules.

When the host controller encounters an FSTN during microframes 2 through 7 it simply follows the node's Normal Path Link Pointer to access the next schedule data structure. Note that the FSTN's Normal Path Link Pointer[T] bit may set, which the host controller must interpret as the end of periodic list mark.

When the host controller encounters a Save-Place FSTN in microframes 0 or 1, it saves the value of the Normal Path Link Pointer and sets an internal flag indicating that it is executing in Recovery Path mode. Recovery Path mode modifies the host controller's rules for how it traverses the schedule and limits which data structures are considered for execution of bus transactions. The host controller continues executing in Recovery Path mode until it encounters a Restore FSTN or it determines that it has reached the end of the microframe.

The rules for schedule traversal and limited execution while in Recovery Path mode are:

- Always follow the Normal Path Link Pointer when it encounters an FSTN that is a Save-Place indicator. The host controller must not recursively follow Save-Place FSTNs. Therefore, while executing in Recovery Path mode, it must never follow an FSTN's Back Path Link Pointer.
- Do not process an siTD or iTD data structure; simply follow its Next Link Pointer.
- Do not process a QH (Queue Head) whose EPS field indicates a high-speed device; simply follow its Horizontal Link Pointer.
- When a QH's EPS field indicates a Full/Low-speed device, the host controller only considers it for execution if its SplitXState is DoComplete (note: this applies whether the PID Code indicates an IN or an OUT). Refer to the *EHCI Specification* for a complete list of additional conditions that must be met in general for the host controller to issue a bus transaction. Note that the host controller must not execute a Start-split transaction while executing in Recovery Path mode. Refer to the *EHCI Specification* for special handling when in Recovery Path mode.
- Stop traversing the recovery path when it encounters an FSTN that is a Restore indicator. The host controller unconditionally uses the saved value of the Save-Place FSTN's Normal Path Link Pointer when returning to the normal path traversal. The host controller must clear the context of executing a Recovery Path when it restores schedule traversal to the Save-Place FSTN's Normal Path Link Pointer.

If the host controller determines that there is not enough time left in the microframe to complete processing of the periodic schedule, it abandons traversal of the recovery path, and clears the context of executing a recovery path. The result is that at the start of the next consecutive microframe, the host controller starts traversal at the frame list.

An example traversal of a periodic schedule that includes FSTNs is illustrated in the figure below.



Figure 17-56. Example host controller traversal of recovery path via FSTNs

In frame N (microframes 0-7), for this example, the host controller traverses all of the schedule data structures utilizing the Normal Path Link Pointers in any FSTNs it encounters. This is because the host controller has not yet encountered a Save-Place FSTN so it is not executing in Recovery Path mode. When it encounters the Restore FSTN, (Restore-N), during microframes 0 and 1, it uses Restore-N. Normal Path Link Pointer to traverse to the next data structure (that is, normal schedule traversal). This is because the host controller must use a Restore FSTN's Normal Path Link Pointer when not executing in a Recovery-Path mode. The nodes traversed during frame N include:  $\{8_{2.0}, 8_{2.1}, 8_{2.2}, 8_{2.3}, 4_2, 2_0, Restore-N, 1_0 ...\}$ .

In frame N+1 (microframes 0 and 1), when the host controller encounters Save-Path FSTN (Save-N), it observes that Save-N.Back Path Link Pointer.T-bit is zero (definition of a Save-Path indicator). The host controller saves the value of Save-N. Normal Path Link Pointer and follows Save-N.Back Path Link Pointer. At the same time, it sets an internal flag indicating that it is now in Recovery Path mode (the recovery path is annotated in the figure above with a large dashed line). The host controller continues traversing data structures on the recovery path and executing only those bus transactions as noted above, on the recovery path until it reaches Restore FSTN (Restore-N). Restore-N.Back Path Link Pointer.T-bit is set (definition of a Restore indicator), so the host controller exits Recovery Path mode by clearing the internal Recovery Path mode flag and commences (restores) schedule traversal using the saved value of the Save-Place FSTN's Normal Path Link Pointer (for example, Save-N.Normal Path Link Pointer). The nodes traversed during these microframes include: {83.0, 83.1, 83.2, Save-A, 82.2, 82.3, 42, 20, Restore-N, 43, 21, Restore-N, 10 ...}.

In frame N+1 (microframes 2-7), when the host controller encounters Save-Path FSTN Save-N, it unconditionally follows Save-N.Normal Path Link Pointer. The nodes traversed during these microframes include:  $\{8_{3.0}, 8_{3.1}, 8_{3.2}, \text{Save-A}, 4_3, 2_1, \text{Restore-N}, 1_0 ...\}$ .

## 17.6.12.2.3 Software operational model for FSTNs

Software must create a consistent, coherent schedule for the host controller to traverse.

When using FSTNs, system software must adhere to the following rules:

• Each Save-Place indicator requires a matching Restore indicator.

The Save-Place indicator is an FSTN with a valid Back Path Link Pointer and T-bit equal to zero. Note that Back Path Link Pointer[Typ] field must be set to indicate the referenced data structure is a queue head. The Restore indicator is an FSTN with its Back Path Link Pointer[T] bit set.

A Restore FSTN may be matched to one or more Save-Place FSTNs. For example, if the schedule includes a poll-rate 1 level, then system software only needs to place a Restore FSTN at the beginning of this list in order to match all possible Save-Place FSTNs.

- If the schedule does not have elements linked at a poll-rate level of one, and one or more Save-Place FSTNs are used, then System Software must ensure the Restore FSTN's Normal Path Link Pointer's T-bit is set, as this is used to mark the end of the periodic list.
- When the schedule does have elements linked at a poll rate level of one, a Restore FSTN must be the first data structure on the poll rate one list. All traversal paths from the frame list converge on the poll-rate one list. System software must ensure that Recovery Path mode is exited before the host controller is allowed to traverse the poll rate level one list.
- A Save-Place FSTN's Back Path Link Pointer must reference a queue head data structure. The referenced queue head must be reachable from the previous frame list location. In other words, if the Save-Place FSTN is reachable from frame list offset N, then the FSTN's Back Path Link Pointer must reference a queue head that is reachable from frame list offset N-1.

Software should make the schedule as efficient as possible. What this means in this context is that software should have no more than one Save-Place FSTN reachable in any single frame. Note there are times when two (or more, depending on the implementation) could exist as full-/low-speed footprints change with bandwidth adjustments. This could

occur, for example when a bandwidth rebalance causes system software to move the Save-Place FSTN from one poll rate level to another. During the transition, software must preserve the integrity of the previous schedule until the new schedule is in place.

## 17.6.12.2.4 Tracking split transaction progress for interrupt transfers

To correctly maintain the data stream, the host controller must be able to detect and report errors where data is lost.

For interrupt-IN transfers, data is lost when it makes it into the USB 2.0 hub, but the USB 2.0 host system is unable to get it from the USB 2.0 hub and into the system before it expires from the transaction translator pipeline. When a lost data condition is detected, the queue is halted, thus signaling system software to recover from the error. A data-loss condition exists whenever a start-split is issued, accepted and successfully executed by the USB 2.0 hub, but the complete-splits get unrecoverable errors on the high-speed link, or the complete-splits do not occur at the correct times. One reason complete-splits might not occur at the right time would be due to host-induced system hold-offs that cause the host controller to miss bus transactions because it cannot get timely access to the schedule in system memory.

The same condition can occur for an interrupt-OUT, but the result is not an endpoint halt condition, but rather effects only the progress of the transfer. The queue head has the following fields to track the progress of each split transaction. These fields are used to keep incremental state about which (and when) portions have been executed.

- C-prog-mask. This is an eight-bit bit-vector where the host controller keeps track of which complete-splits have been executed. Due to the nature of the transaction translator periodic pipeline, the complete-splits need to be executed in-order. The host controller needs to detect when the complete-splits have not been executed in order. This can only occur due to system hold-offs where the host controller cannot get to the memory-based schedule. C-prog-mask is a simple bit-vector that the host controller sets one of the C-prog-mask bits for each complete-split executed. The bit position is determined by the microframe number in which the complete-split was executed. The host controller always checks C-prog-mask before executing a complete-split transaction. If the previous complete-splits have not been executed then it means one (or more) have been skipped and data has potentially been lost.
- FrameTag. This field is used by the host controller during the complete-split portion of the split transaction to tag the queue head with the frame number (H-Frame number) when the next complete split must be executed.
- S-bytes. This field can be used to store the number of data payload bytes sent during the start-split (if the transaction was an OUT). The S-bytes field must be used to accumulate the data payload bytes received during the complete-splits (for an IN).

## 17.6.12.2.5 Split transaction execution state machine for interrupt

In the following section, all references to microframe are in the context of a microframe within an H-Frame.

As with asynchronous full- and low-speed endpoints, a split-transaction state machine is used to manage the split transaction sequence. Aside from the fields defined in the queue head for scheduling and tracking the split transaction, the host controller calculates one internal mechanism that is also used to manage the split transaction. The internal calculated mechanism is:

• cMicroFrameBit. This is a single-bit encoding of the current microframe number. It is an eight-bit value calculated by the host controller at the beginning of every microframe. It is calculated from the three least significant bits of the FRINDEX register (that is, cMicroFrameBit = (1 shifted-left(FRINDEX[2-0]))). The cMicroFrameBit has at most one bit asserted, which always corresponds to the current microframe number. For example, if the current microframe is 0, then cMicroFrameBit will equal 0b0000\_0001.

The variable cMicroFrameBit is used to compare against the S-mask and C-mask fields to determine whether the queue head is marked for a start- or complete-split transaction for the current microframe.

The figure below illustrates how a complete interrupt split transaction is managed. There are two phases to each split transaction. The first is a single start-split transaction, which occurs when the SplitXState is at Do\_Start and the single bit in cMicroFrameBit has a corresponding bit active in QH[S-mask]. The transaction translator does not acknowledge the receipt of the periodic start-split, so the host controller unconditionally transitions the state to Do\_Complete. Due to the available jitter in the transaction translator pipeline, there is more than one complete-split transaction scheduled by software for the Do\_Complete state. This translates simply to the fact that there are multiple bits set in the QH[C-mask] field.

The host controller keeps the queue head in the Do\_Complete state until the split transaction is complete (see definition below), or an error condition triggers the three-strikes-rule (for example, after the host tries the same transaction three times, and each encounters an error, the host controller stops retrying the bus transaction and halts the endpoint, thus requiring system software to detect the condition and perform system-dependent recovery).



Figure 17-57. Split transaction state machine for interrupt

## 17.6.12.2.6 Periodic interrupt-do-start-split

This is the state when software must initialize a full- or low-speed interrupt queue head StartXState bit. This state is entered from the Do\_Complete Split state only after the split transaction is complete.

This occurs when one of the following events occur: The transaction translator responds to a complete-split transaction with one of the following:

- NAK. A NAK response is a propagation of the full- or low-speed endpoint's NAK response.
- ACK. An ACK response is a propagation of the full- or low-speed endpoint's ACK response. Only occurs on an OUT endpoint.
- DATA 0/1. Only occurs for INs. Indicates that this is the last of the data from the endpoint for this split transaction.
- ERR. The transaction on the low-/full-speed link below the transaction translator had a failure (for example, timeout, bad CRC, and so on).
- NYET (and Last). The host controller issued the last complete-split and the transaction translator responded with a NYET handshake. This means that the start-split was not correctly received by the transaction translator, so it never executed a

transaction to the full- or low-speed endpoint, see Periodic interrupt-do-complete-split, for the definition of 'Last'.

Each time the host controller visits a queue head in this state (once within the execute transaction state), bit-wise ANDs QH[S-mask] with cMicroFrameBit to determine whether to execute a start-split. If the result is non-zero, then the host controller issues a start-split transaction. If the PID Code field indicates an IN transaction, the host controller must zero-out the QH[S-bytes] field. After the split-transaction has been executed, the host controller sets up state in the queue head to track the progress of the complete-split phase of the split transaction. Specifically, it records the expected frame number into QH[FrameTag] field, sets C-prog-mask to zero (0x00), and exits this state. Note that the host controller must not adjust the value of Cerr as a result of completion of a start-split transaction.

## 17.6.12.2.7 Periodic interrupt-do-complete-split

This state is entered unconditionally from the Do-Start-Split state after a start-split transaction is executed on the bus.

Each time the host controller visits a queue head in this state (once within the execute transaction state), it checks to determine whether a complete-split transaction should be executed now.

There are four tests to determine whether a complete-split transaction should be executed.

- Test A. cMicroFrameBit is bit-wise ANDed with QH[C-mask] field. A non-zero result indicates that software scheduled a complete-split for this endpoint, during this microframe.
- Test B. QH[FrameTag] is compared with the current contents of FRINDEX[7-3]. An equal indicates a match.
- Test C. The complete-split progress bit vector is checked to determine whether the previous bit is set, indicating that the previous complete-split was appropriately executed. An example algorithm for this test is provided below:

```
Algorithm Boolean CheckPreviousBit(QH.C-prog-mask, QH.C-mask, cMicroFrameBit)

Begin

-- Return values:

-- TRUE - no error

-- FALSE - error

-- Boolean rvalue = TRUE;

previousBit = cMicroframeBit logical-rotate-right(1)
```

```
-- Bit-wise anding previousBit with C-mask indicates
-- whether there was an intent
-- to send a complete split in the previous microframe. So,
-- if the
  'previous bit' is set in C-mask, check C-prog-mask to
-- make sure it
-- happened.
If (previousBit bitAND QH.C-mask)then
If not(previousBit bitAND QH.C-prog-mask) then
         rvalue = FALSE;
     End if
End If
-- If the C-prog-mask already has a one in this bit position,
-- then an aliasing
-- error has occurred. It will probably get caught by the
-- FrameTag Test, but
-- at any rate it is an error condition that as detectable here
-- should not allow
-- a transaction to be executed.
If (cMicroFrameBit bitAND OH.C-prog-mask) then
rvalue = FALSE;
End if
return (rvalue)
End Algorithm
```

• Test D. Check to see if a start-split should be executed in this microframe. Note this is the same test performed in the Do Start Split state. Whenever it evaluates to TRUE and the controller is NOT processing in the context of a Recovery Path mode, it means a start-split should occur in this microframe. Test D and Test A evaluating to TRUE at the same time is a system software error. Behavior is undefined.

If (Test A and B and C and not(D)) then the host controller will execute a complete-split transaction. When the host controller commits to executing the complete-split transaction, it updates QH[C-prog-mask] by bit-ORing with cMicroFrameBit. On completion of the complete-split transaction, the host controller records the result of the transaction in the queue head and sets QH[FrameTag] to the expected H-Frame number. The effect to the state of the queue head and thus the state of the transfer depends on the response by the

transaction translator to the complete-split transaction. The following responses have the effects (note that any responses that result in decrementing of the Cerr will result in the queue head being halted by the host controller if the result of the decrement is zero):

### • NYET (and Last)

On each NYET response, the host controller checks to determine whether this is the last complete-split for this split transaction. Last is defined in this context as the condition where all of the scheduled complete-splits have been executed. If it is the last complete-split (with a NYET response), then the transfer state of the queue head is not advanced (never received any data) and this state exited. The transaction translator must have responded to all the complete-splits with NYETs, meaning that the start-split issued by the host controller was not received. The start-split should be retried at the next poll period.

The test for whether this is the Last complete split can be performed by XOR QH[C-mask] with QH[C-prog-mask]. If the result is all zeros then all complete-splits have been executed. When this condition occurs, the XactErr status bit is set and the Cerr field is decremented.

### • NYET (and not Last)

See above description for testing for Last. The complete-split transaction received a NYET response from the transaction translator. Do not update any transfer state (except for C-prog-mask and FrameTag) and stay in this state. The host controller must not adjust Cerr on this response.

### • Transaction Error (XactErr). Timeout, data CRC failure, and so on

The Cerr field is decremented and the XactErr bit in the Status field is set. The complete split transaction is immediately retried (if Cerr is non-zero). If there is not enough time in the microframe to complete the retry and the endpoint is an IN, or Cerr is decremented to a zero from a one, the queue is halted. If there is not enough time in the microframe to complete the retry and the endpoint is an OUT and Cerr is not zero, then this state is exited (that is, return to Do Start Split). This results in a retry of the entire OUT split transaction, at the next poll period. Refer to Chapter 11 Hubs (specifically the section on full- and low-speed interrupts) in the *USB Specification Revision 2.0* for detailed requirements on why these errors must be immediately retried.

### ACK

This can only occur if the target endpoint is an OUT. The target endpoint ACK'd the data and this response is a propagation of the endpoint ACK up to the host controller. The host controller must advance the state of the transfer. The Current Offset field is incremented by Maximum Packet Length or Bytes to Transfer, whichever is less. The

field Bytes To Transfer is decremented by the same amount. And the data toggle bit (dt) is toggled. The host controller will then exit this state for this queue head. The host controller must reload Cerr with maximum value on this response. Advancing the transfer state may cause other process events such as retirement of the qTD and advancement of the queue.

#### MDATA

This response will only occur for an IN endpoint. The transaction translator responded with zero or more bytes of data and an MDATA PID. The incremental number of bytes received is accumulated in QH[S-bytes]. The host controller must not adjust Cerr on this response.

### • DATA0/1

This response may only occur for an IN endpoint. The number of bytes received is added to the accumulated byte count in QH[S-bytes]. The state of the transfer is advanced by the result and the host controller exits this state for this queue head.

Advancing the transfer state may cause other processing events such as retirement of the qTD and advancement of the queue.

If the data sequence PID does not match the expected, the entirety of the data received in this split transaction is ignored, the transfer state is not advanced and this state is exited.

#### NAK

The target endpoint Nak'd the full- or low-speed transaction. The state of the transfer is not advanced, and this state is exited. The host controller must reload Cerr with maximum value on this response.

#### • ERR

There was an error during the full- or low-speed transaction. The ERR status bit is set, Cerr is decremented, the state of the transfer is not advanced, and this state is exited.

### • STALL

The queue is halted (an exit condition of the Execute Transaction state). The status field bits: Active bit is cleared and the Halted bit is set and the qTD is retired. Responses which are not enumerated in the list or which are received out of sequence are illegal and may result in undefined host controller behavior. The other possible combinations of tests A, B, C, and D may indicate that data or response was lost. The table below lists the possible combinations and the appropriate action.

Table 17-79. Interrupt IN/OUT do complete split state execution criteria

| Condition   | Action                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| not(A)      | Ignore QHD                                                 | Neither a start nor complete-split is scheduled for the current microframe. Host                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| not(D)      |                                                            | controller should continue walking the schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| A<br>not(C) | If PIDCode = IN Halt QHDIf PIDCode = OUT Retry start-split | Progress bit check failed. These means a complete-split has been missed. There is the possibility of lost data. If PID Code is an IN, then the queue head must be halted. If PID Code is an OUT, then the transfer state is not advanced and the state exited (for example, start-split is retried). This is a host-induced error and does not effect Cerr. In either case, set the Missed Microframe bit in the status field to a one.                                                                                                                                                                                                                                                                          |
| Α           | If PIDCode = IN                                            | QH.FrameTag test failed. This means that exactly one or more H-Frames have                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| not(B)      | Halt QHD                                                   | been skipped. This means complete-splits and have missed. There is the possibility of lost data. If PID Code is an IN, then the queue head must be halted. If                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| С           | If PIDCode = OUT                                           | PID Code is an OUT, then the transfer state is not advanced and the state exited                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|             | Retry start-split                                          | (for example, start-split is retried). This is a host-induced error and does not effect Cerr. In either case, set the Missed Microframe bit in the status field to a one.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| А           | Execute complete-split                                     | This is the non-error case where the host controller executes a complete-split                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| В           |                                                            | transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| С           |                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| not(D)      |                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| D           | If PIDCode = IN                                            | This is a degenerate case where the start-split was issued, but all of the complete-<br>splits were skipped and all possible intervening opportunities to detect the missed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|             | Halt QHDIf PIDCode = OUT Retry start-split                 | data failed to fire. If PID Code is an IN, then the Queue head must be halted. If PID Code is an OUT, then the transfer state is not advanced and the state exited (for example, start-split is retried). This is a host-induced error and does not effect Cerr. In either case, set the Missed Microframe bit in the status field to a one. Note that when executing in the context of a Recovery Path mode, the host controller is allowed to process the queue head and take the actions indicated above, or it may wait until the queue head is visited in the normal processing mode. Regardless, the host controller must not execute a start-split in the context of a executing in a Recovery Path mode. |

# 17.6.12.2.8 Managing the QH[FrameTag] field

The QH[FrameTag] field in a queue head is completely managed by the host controller.

The rules for setting QH[FrameTag] are simple:

- Rule 1: If transitioning from Do Start Split to Do Complete Split and the current value of FRINDEX[2-0] is 6, QH[FrameTag] is set to FRINDEX[7-3] + 1. This accommodates split transactions whose start-split and complete-splits are in different H-Frames (case 2a, see Figure 17-54).
- Rule 2: If the current value of FRINDEX[2-0] is 7, QH[FrameTag] is set to FRINDEX[7-3] + 1. This accommodates staying in Do Complete Split for cases 2a, 2b, and 2c in Figure 17-54.
- Rule 3: If transitioning from Do\_Start Split to Do Complete Split and the current value of FRINDEX[2-0] is not 6, or currently in Do Complete Split and the current

value of (FRINDEX[2-0]) is not 7, FrameTag is set to FRINDEX[7-3]. This accommodates all other cases in Figure 17-54.

## 17.6.12.2.9 Rebalancing the periodic schedule

System software must occasionally adjust a periodic queue head's S-mask and C-mask fields during operation.

This need occurs when adjustments to the periodic schedule create a new bandwidth budget and one or more queue head's are assigned new execution footprints (that is, new S-mask and C-mask values).

It is imperative that system software must not update these masks to new values in the midst of a split transaction. In order to avoid any race conditions with the update, the host controller provides a simple assist to system software. System software sets the Inactivate-on-next-Transaction (I) bit to signal the host controller that it intends to update the S-mask and C-mask on this queue head. System software then waits for the host controller to observe the I-bit is set and transitions the Active bit to a zero. The rules for how and when the host controller clears the Active bit are:

- If the Active bit is cleared, no action is taken. The host controller does not attempt to advance the queue when the I-bit is set.
- If the Active bit is set and the SplitXState is DoStart (regardless of the value of S-mask), the host controller simply clears the Active bit. The host controller is not required to write the transfer state back to the current qTD. Note that if the S-mask indicates that a start-split is scheduled for the current microframe, the host controller must not issue the start-split bus transaction; it must clear the Active bit.

System software must save transfer state before setting the I-bit. This is required so that it can correctly determine what transfer progress (if any) occurred after the I-bit was set and the host controller executed it's final bus-transaction and cleared the Active bit.

After system software has updated the S-mask and C-mask, it must then reactivate the queue head. Since the Active bit and the I-bit cannot be updated with the same write, system software needs to use the following algorithm to coherently re-activate a queue head that has been stopped using the I-bit.

- 1. Set the Halted bit, then
- 2. Clear the I-bit, then
- 3. Set the Active bit and clear the Halted bit in the same write.

Setting the Halted bit inhibits the host controller from attempting to advance the queue between the time the I-bit is cleared and the Active bit is set.

## 17.6.12.3 Split transaction isochronous

Full-speed isochronous transfers are managed using the split-transaction protocol through a USB 2.0 transaction translator in a USB 2.0 hub.

The host controller utilizes siTD data structure to support the special requirements of isochronous split-transactions. This data structure uses the scheduling model of isochronous TDs (see Managing isochronous transfers using iTDs, for the operational model of iTDs) with the contiguous data feature provided by queue heads. This simple arrangement allows a single isochronous scheduling model and adds the additional feature that all data received from the endpoint (per split transaction) must land into a contiguous buffer.

## 17.6.12.3.1 Split transaction scheduling mechanisms for isochronous

Full-speed isochronous transactions are managed through a transaction translator's periodic pipeline.

As with full- and low-speed interrupt, system software manages each transaction translator's periodic pipeline by budgeting and scheduling exactly during which microframes the start-splits and complete-splits for each full-speed isochronous endpoint occur. The requirements described in Split transaction scheduling mechanisms for interrupt, apply.

Figure 17-58 illustrates the general scheduling boundary conditions that are supported by the EHCI periodic schedule. The  $S_n$  and  $C_n$  labels indicate microframes where software can schedule start- and complete-splits (respectively). The H-Frame boundaries are marked with a large, solid bold vertical line. The B-Frame boundaries are marked with a large, bold, dashed line. The bottom of the figure below illustrates the relationship of an siTD to the H-Frame.



Figure 17-58. Split transaction, isochronous scheduling boundary conditions

When the endpoint is an isochronous OUT, there are only start-splits, and no complete-splits. When the endpoint is an isochronous IN, there is at most one start-split and one to N complete-splits. The scheduling boundary cases are:

- Case 1: The entire split transaction is completely bounded by an H-Frame. For example, the start-splits and complete-splits are all scheduled to occur in the same H-Frame.
- Case 2a: This boundary case is where one or more (at most two) complete-splits of a split transaction IN are scheduled across an H-Frame boundary. This can only occur when the split transaction has the possibility of moving data in B-Frame, microframes 6 or 7 (H-Frame microframe 7 or 0). When an H-Frame boundary wrap condition occurs, the scheduling of the split transaction spans more than one location in the periodic list.(for example, it takes two siTDs in adjacent periodic frame list locations to fully describe the scheduling for the split transaction).

Although the scheduling of the split transaction may take two data structures, all of the complete-splits for each full-speed IN isochronous transaction must use only one data pointer. For this reason, siTDs contain a back pointer.

Software must never schedule full-speed isochronous OUTs across an H-Frame boundary.

• Case 2b: This case can only occur for a very large isochronous IN. It is the only allowed scenario where a start-split and complete-split for the same endpoint can occur in the same microframe. Software must enforce this rule by scheduling the large transaction first. Large is defined to be anything larger than 579 byte maximum packet size.

A subset of the same mechanisms employed by full- and low-speed interrupt queue heads are employed in siTDs to schedule and track the portions of isochronous split transactions. The following fields are initialized by system software to instruct the host controller when to execute portions of the split transaction protocol:

# • SplitXState

This is a single bit residing in the Status field of an siTD (see Table 17-57). This bit is used to track the current state of the split transaction. The rules for managing this bit are described in Split transaction execution state machine for isochronous.

#### • Frame S-mask

This is a bit-field wherein system software sets a bit corresponding to the microframe (within an H-Frame) that the host controller should execute a start-split transaction. This is always qualified by the value of the SplitXState bit. For example, referring to the IN example in Figure 17-58, case 1, the S-mask would have a value of 0b0000\_0001 indicating that if the siTD is traversed by the host controller, and the SplitXState indicates Do Start Split, and the current microframe as indicated by FRINDEX[2-0] is 0, then execute a start-split transaction.

### Frame C-mask

This is a bit-field where system software sets one or more bits corresponding to the microframes (within an H-Frame) that the host controller should execute complete-split transactions. The interpretation of this field is always qualified by the value of the SplitXState bit. For example, referring to the IN example in Figure 17-58, case 1, the C-mask would have a value of 0b 0011\_1100 indicating that if the siTD is traversed by the host controller, and the SplitXState indicates Do Complete Split, and the current microframe as indicated by FRINDEX[2-0] is 2, 3, 4, or 5, then execute a complete-split transaction.

### Back Pointer

This field in a siTD is used to complete an IN split-transaction using the previous H-Frame's siTD. This is only used when the scheduling of the complete-splits span an H-Frame boundary.

There exists a one-to-one relationship between a high-speed isochronous split transaction (including all start- and complete-splits) and one full-speed isochronous transaction. An siTD contains (amongst other things) buffer state and split transaction scheduling information. An siTD's buffer state always maps to one full-speed isochronous data payload. This means that for any full-speed transaction payload, a single siTD's data buffer must be used. This rule applies to both IN an OUTs. An siTD's scheduling information usually also maps to one high-speed isochronous split transaction. The exception to this rule is the H-Frame boundary wrap cases mentioned above.

The siTD data structure describes at most, one frame's worth of high-speed transactions and that description is strictly bounded within a frame boundary. The figure below illustrates some examples. On the top are examples of the full-speed transaction footprints for the boundary scheduling cases described above. In the middle are time-frame references for both the B-Frames (HS/FS/LS Bus) and the H-Frames. On the bottom is illustrated the relationship between the scope of an siTD description and the time references. Each H-Frame corresponds to a single location in the periodic frame list. The implication is that each siTD is reachable from a single periodic frame list location at a time.



Figure 17-59. siTD scheduling boundary examples

Each case is described below:

- Case 1: One siTD is sufficient to describe and complete the isochronous split transaction because the whole isochronous split transaction is tightly contained within a single H-Frame.
- Case 2a, 2b: Although both INs and OUTs can have these footprints, OUTs always take only one siTD to schedule. However, INs (for these boundary cases) require two siTDs to complete the scheduling of the isochronous split transaction. siTDX is used to always issue the start-split and the first N complete-splits. The full-speed transaction (for these cases) can deliver data on the full-speed bus segment during microframe 7 of H-Frame $_{Y+1}$ , or microframe 0 of H-Frame $_{Y+2}$ . The complete splits are scheduled using siTD $_{X+2}$  (not shown). The complete-splits to extract this data must use the buffer pointer from siTD $_{X+1}$ . The only way for the host controller to reach siTD $_{X+1}$  from H-Frame $_{Y+2}$  is to use siTD $_{X+2}$ 's back pointer.

Software must apply the following rules when calculating the schedule and linking the schedule data structures into the periodic schedule:

- Software must ensure that an isochronous split-transaction is started so that it will complete before the end of the B-Frame.
- Software must ensure that for a single full-speed isochronous endpoint, there is never a start-split and complete-split in H-Frame, microframe 1. This is mandated as a rule so that case 2a and case 2b can be discriminated. According to the core USB specification, the long isochronous transaction illustrated in Case 2b, could be scheduled so that the start-split was in microframe 1 of H-Frame N and the last complete-split would need to occur in microframe 1 of H-Frame N+1. However, it is impossible to discriminate between cases 2a and case 2b, which has significant impact on the complexity of the host controller.

## 17.6.12.3.2 Tracking split transaction progress for isochronous transfers

Isochronous endpoints do not employ the concept of a halt on error, however the host controller does identify and report per-packet errors observed in the data stream.

This includes schedule traversal problems (skipped microframes), timeouts and corrupted data received.

In similar kind to interrupt split-transactions, the portions of the split transaction protocol must execute in the microframes they are scheduled. The queue head data structure used to manage full- and low-speed interrupt has several mechanisms for tracking when portions of a transaction have occurred. Isochronous transfers use siTDs for their transfers and the data structures are only reachable using the schedule in the exact microframe in which they are required (so all the mechanism employed for tracking in queue heads is not required for siTDs). Software has the option of reusing siTD several times in the complete periodic schedule. However, it must ensure that the results of split transaction N are consumed and the siTD re-initialized (activated) before the host controller gets back to the siTD (in a future microframe).

Split-transaction isochronous OUTs utilize a low-level protocol to indicate which portions of the split transaction data have arrived. Control over the low-level protocol is exposed in an siTD using the fields Transaction Position (TP) and Transaction Count (T-count). If the entire data payload for the OUT split transaction is larger than 188 bytes, there will be more than one start-split transaction, each of which require proper annotation. If host hold-offs occur, then the sequence of annotations received from the host will not be complete, which is detected and handled by the transaction translator. See Split transaction scheduling mechanisms for isochronous, for a description on how these fields are used during a sequence of start-split transactions.

The fields siTD[T-Count] and siTD[TP] are used by the host controller to drive and sequence the transaction position annotations. It is the responsibility of system software to properly initialize these fields in each siTD. Once the budget for a split-transaction

isochronous endpoint is established, S-mask, T-Count, and TP initialization values for all the siTD associated with the endpoint are constant. They remain constant until the budget for the endpoint is recalculated by software and the periodic schedule adjusted.

For IN-endpoints, the transaction translator simply annotates the response data packets with enough information to allow the host controller to identify the last data. As with split transaction Interrupt, it is the host controller's responsibility to detect when it has missed an opportunity to execute a complete-split. The following field in the siTD is used to track and detect errors in the execution of a split transaction for an IN isochronous endpoint.

• C-prog-mask. This is an eight-bit bit-vector where the host controller keeps track of which complete-splits have been executed. Due to the nature of the transaction translator periodic pipeline, the complete-splits need to be executed in-order. The host controller needs to detect when the complete-splits have not been executed in order. This can only occur due to system hold-offs where the host controller cannot get to the memory-based schedule. C-prog-mask is a simple bit-vector that the host controller sets a bit for each complete-split executed. The bit position is determined by the microframe (FRINDEX[2-0]) number in which the complete-split was executed. The host controller always checks C-prog-mask before executing a complete-split transaction. If the previous complete-splits have not been executed, then it means one (or more) have been skipped and data has potentially been lost. System software is required to initialize this field to zero before setting an siTD's Active bit to a one.

If a transaction translator returns with the final data before all of the complete-splits have been executed, the state of the transfer is advanced so that the remaining complete-splits are not executed. It is important to note that an IN siTD is retired based solely on the responses from the transaction translator to the complete-split transactions. This means, for example, that it is possible for a transaction translator to respond to a complete-split with an MDATA PID. The number of bytes in the MDATA's data payload could cause the siTD[Total Bytes to Transfer] field to decrement to zero. This response can occur, before all of the scheduled complete-splits have been executed. In other interface, data structures (for example, high-speed data streams through queue heads), the transition of Total Bytes to Transfer to zero signals the end of the transfer and results in clearing the Active bit. However, in this case, the result has not been delivered by the transaction translator and the host must continue with the next complete-split transaction to extract the residual transaction state. This scenario occurs because of the pipeline rules for a transaction translator. In summary, the periodic pipeline rules require that on a microframe boundary, the transaction translator holds the final two bytes received (if it has not seen an End Of Packet (EOP)) in the full-speed bus pipe stage and gives the remaining bytes to the high-speed pipeline stage. At the microframe boundary, the transaction translator could have received the entire packet (including both CRC bytes)

but not received the packet EOP. In the next microframe, the transaction translator responds with an MDATA and sends all of the data bytes (with the two CRC bytes being held in the full-speed pipeline stage). This could cause the siTD to decrement it's Total Bytes to Transfer field to zero, indicating it has received all expected data. The host must still execute one more (scheduled) complete-split transaction in order to extract the results of the full-speed transaction from the transaction translator (for example, the transaction translator may have detected a CRC failure, and this result must be forwarded to the host).

If the host experiences hold-offs that cause the host controller to skip one or more (but not all) scheduled split transactions for an isochronous OUT, then the protocol to the transaction translator is not consistent and the transaction translator detects and reacts to the problem. Likewise, for host hold-offs that cause the host controller to skip one or more (but not all) scheduled split transactions for an isochronous IN, the C-prog-mask is used by the host controller to detect errors. However, if the host experiences a hold-off that causes it to skip all of an siTD, or an siTD expires during a host hold off (for example, a hold-off occurs and the siTD is no longer reachable by the host controller in order for it to report the hold-off event), then system software must detect that the siTDs have not been processed by the host controller (for example, state not advanced) and report the appropriate error to the client driver.

## 17.6.12.3.3 Split transaction execution state machine for isochronous

In this section, all references to microframe are in the context of a microframe within an H-Frame.

If the active bit in the status byte is a zero, the host controller ignores the siTD and continues traversing the periodic schedule. Otherwise the host controller processes the siTD as specified below. A split transaction state machine is used to manage the split-transaction protocol sequence. The host controller uses the fields defined in Tracking split transaction progress for isochronous transfers, plus the variable cMicroFrameBit defined in Split transaction execution state machine for interrupt, to track the progress of an isochronous split transaction. The figuer below illustrates the state machine for managing an siTD through an isochronous split transaction. Bold, dotted circles denote the state of the Active bit in the Status field of a siTD. The Bold, dotted arcs denote the transitions between these states. Solid circles denote the states of the split transaction state machine and the solid arcs denote the transitions between these states. Dotted arcs and boxes reference actions that take place either as a result of a transition or from being in a state.



Figure 17-60. Split transaction state machine for isochronous

## 17.6.12.3.4 Periodic isochronous-do-start-split

Isochronous split transaction OUTs use only this state.

An siTD for a split-transaction isochronous IN is either initialized to this state, or the siTD transitions to this state from Do Complete Split when a case 2a (IN) or 2b scheduling boundary isochronous split-transaction completes.

Each time the host controller reaches an active siTD in this state, it checks the siTD[S-mask] against cMicroFrameBit. If there is a one in the appropriate position, the siTD executes a start-split transaction. By definition, the host controller cannot reach an siTD at the wrong time. If the I/O field indicates an IN, then the start-split transaction includes only the extended token plus the full-speed token. Software must initialize the siTD[Total Bytes To Transfer] field to the number of bytes expected. This is usually the maximum packet size for the full-speed endpoint. The host controller exits this state when the start-split transaction is complete.

The remainder of this section is specific to an isochronous OUT endpoint (that is, the I/O field indicates an OUT). When the host controller executes a start-split transaction for an isochronous OUT it includes a data payload in the start-split transaction. The memory buffer address for the data payload is constructed by concatenating siTD[Current Offset]

with the page pointer indicated by the page select field (siTD[P]). A zero in this field selects Page 0 and a 1 selects Page 1. During the start-split for an OUT, if the data transfer crosses a page boundary during the transaction, the host controller must detect the page cross, update the siTD[P] bit from a zero to a one, and begin using the siTD Page 1 with siTD[Current Offset] as the memory address pointer. The field siTD[TP] is used to annotate each start-split transaction with the indication of which part of the split-transaction data the current payload represents (ALL, BEGIN, MID, END). In all cases, the host controller simply uses the value in siTD[TP] to mark the start-split with the correct transaction position code.

T-count is always initialized to the number of start-splits for the current frame. TP is always initialized to the first required transaction position identifier. The scheduling boundary case (see Figure 17-59) is used to determine the initial value of TP. The initial cases are summarized in the table below.

| Case  | T-Count | TP    | Description                                                                                                                                                        |  |
|-------|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1, 2a | =1      |       | When the OUT data payload is less than (or equal to) 188 bytes, only one start-split is required to move the data. The one start-split must be marked with an ALL. |  |
| 1, 2a | !=1     | BEGIN | When the OUT data payload is greater than 188 bytes more than one start-split must be used to move the data. The initial start-split must be marked with a BEGIN.  |  |

Table 17-80. Initial conditions for OUT siTD TP and T-count fields

After each start-split transaction is complete, the host controller updates T-count and TP appropriately so that the next start-split is correctly annotated. The table below illustrates all of the TP and T-count transitions, which must be accomplished by the host controller.

| Table 17-81. | <b>Transaction position (TP)/transaction count (T-count)</b> |
|--------------|--------------------------------------------------------------|
|              | transition table                                             |

| TP    | T-Count<br>Next | TP Next | Description                                                                                                                                                                          |
|-------|-----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ALL   | 0               | N/A     | Transition from ALL, to done.                                                                                                                                                        |
| BEGIN | 1               | END     | Transition from BEGIN to END. Occurs when T-count starts at 2.                                                                                                                       |
| BEGIN | !=1             | MID     | Transition from BEGIN to MID. Occurs when T-count starts at greater than 2.                                                                                                          |
| MID   | !=1             | MID     | TP stays at MID while T-count is not equal to 1 (for example, greater than 1). This case can occur for any of the scheduling boundary cases where the T-count starts greater than 3. |
| MID   | 1               | END     | Transition from MID to END. This case can occur for any of the scheduling boundary cases where the T-count starts greater than 2.                                                    |

The start-split transactions do not receive a handshake from the transaction translator, so the host controller always advances the transfer state in the siTD after the bus transaction is complete. To advance the transfer state the following operations take place:

- The siTD[Total Bytes To Transfer] and the siTD[Current Offset] fields are adjusted to reflect the number of bytes transferred.
- The siTD[P] (page select) bit is updated appropriately.
- The siTD[TP] and siTD[T-count] fields are updated appropriately as defined in Table 17-81.

These fields are then written back to the memory based siTD. The S-mask is fixed for the life of the current budget. As mentioned above, TP and T-count are set specifically in each siTD to reflect the data to be sent from this siTD. Therefore, regardless of the value of S-mask, the actual number of start-split transactions depends on T-count (or equivalently, Total Bytes to Transfer). The host controller must clear the Active bit when it detects that all of the schedule data has been sent to the bus. Setting the Active bit to zero depends on siTD.TP being 00 or 11, and siTD.Total Bytes decrements to 0. Software must ensure that TP, T-count and Total Bytes to Transfer are set to deliver the appropriate number of bus transactions from each siTD. An inconsistent combination yields undefined behavior.

If the host experiences hold-offs that cause the host controller to skip start-split transactions for an OUT transfer, the state of the transfer does not progress appropriately. The transaction translator observes protocol violations in the arrival of the start-splits for the OUT endpoint (that is, the transaction position annotation is incorrect as received by the transaction translator).

Example scenarios are described in Split transaction for isochronous-processing example.

The host controller can optionally track the progress of an OUT split transaction by setting appropriate bits in the siTD[C-prog-mask] as it executes each scheduled start-split. The checkPreviousBit() algorithm defined in Periodic isochronous-do complete split, can be used prior to executing each start-split to determine whether start-splits were skipped. The host controller can use this mechanism to detect missed microframes. It can then clear the siTD's Active bit and stop execution of this siTD. This saves on both memory and high-speed bus bandwidth.

# 17.6.12.3.5 Periodic isochronous-do complete split

This state is only used by a split-transaction isochronous IN endpoint. This state is entered unconditionally from the Do Start State after a start-split transaction is executed for an IN endpoint.

Each time the host controller visits an siTD in this state, it conducts a number of tests to determine whether it should execute a complete-split transaction. The sequence in which they are applied depends on which microframe the host controller is currently executing, which means that the tests might not be applied until after the siTD referenced from the back pointer has been fetched. The individual tests are as follows.

### • Test A

cMicroFrameBit is bit-wise ANDed with the siTD[C-mask] field. A non-zero result indicates that software scheduled a complete-split for this endpoint, during this microframe. This test is always applied to a newly fetched siTD that is in this state.

#### • Test B

The siTD[C-prog-mask] bit vector is checked to determine whether the previous complete splits have been executed. An example algorithm is given below (this is slightly different than the algorithm used in Periodic interrupt-do-complete-split). The sequence in which this test is applied depends on the current value of FRINDEX[2-0]. If FRINDEX[2-0] is 0 or 1, it is not applied until the back pointer has been used. Otherwise it is applied immediately.

```
Algorithm Boolean CheckPreviousBit(siTD.C-prog-mask, siTD.C-mask, cMicroFrameBit)

Begin

Boolean rvalue = TRUE;

previousBit = cMicroFrameBit rotate-right(1)

-- Bit-wise anding previousBit with C-mask indicates whether there

-- was an intent to send a complete split in the previous micro-

-- frame. So, if the 'previous bit' is set in C-mask, check

-- C-prog-mask to make sure it happened.

if previousBit bitAND siTD.C-mask then

if not (previousBit bitAND siTD.C-prog-mask) then

rvalue = FALSE

End if

End if

Return rvalue

End Algorithm
```

If Test A is true and FRINDEX[2-0] is zero or one, this is a case 2a or 2b scheduling boundary (see Figure 17-58). See Complete-split for scheduling boundary cases 2a, 2b, for details in handling this condition.

If Test A and Test B evaluate to true, the host controller executes a complete-split transaction using the transfer state of the current siTD. When the host controller commits to executing the complete-split transaction, it updates QH[C-prog-mask] by bit-ORing with cMicroFrameBit. The transfer state is advanced based on the completion status of the complete-split transaction. To advance the transfer state of an IN siTD, the host controller must perform the following actions:

- 1. Decrement the number of bytes received from siTD[Total Bytes To Transfer]
- 2. Adjust siTD[Current Offset] by the number of bytes received
- 3. Adjust the siTD[P] (page select) field if the transfer caused the host controller to use the next page pointer
- 4. Set any appropriate bits in the siTD[Status] field, depending on the results of the transaction.

Note that if the host controller encounters a condition where siTD[Total Bytes To Transfer] is zero, and it receives more data, the host controller must not write the additional data to memory. The siTD[Status-Active] bit must be cleared and the siTD[Status-Babble Detected] bit must be set. The fields siTD[Total Bytes To Transfer], siTD[Current Offset], and siTD[P] are not required to be updated as a result of this transaction attempt.

The host controller accepts (assuming good data packet CRC and sufficient room in the buffer as indicated by the value of siTD[Total Bytes To Transfer]) MDATA and DATA0/1 data payloads up to and including 192 bytes. The host controller may optionally clear siTD[Status-Active] and set siTD[Status-Babble Detected] when it receives MDATA or DATA0/1 with a data payload of more than 192 bytes. The following responses have the noted effects:

#### ERR

The full-speed transaction completed with a time-out or bad CRC and this is a reflection of that error to the host. The host controller sets the ERR bit in the siTD[Status] field and clears the Active bit.

### Transaction Error (XactErr)

The complete-split transaction encounters a Timeout, CRC16 failure, and so on. The siTD[Status] field XactErr field is set and the complete-split transaction must be retried immediately. The host controller must use an internal error counter to count the number of retries as a counter field is not provided in the siTD data structure. The host controller will not retry more than two times. If the host controller exhausts the retries or the end of the microframe occurs, the Active bit is cleared.

# • DATAx (0 or 1)

This response signals that the final data for the split transaction has arrived. The transfer state of the siTD is advanced and the Active bit is cleared. If the Bytes To Transfer field has not decremented to zero (including the reception of the data payload in the DATAx response), then less data than was expected, or allowed for was actually received. This short packet event does not set the USB interrupt status bit (USBSTS[UI]) to a one. The host controller will not detect this condition.

### • NYET (and Last)

On each NYET response, the host controller also checks to determine whether this is the last complete-split for this split transaction. Last was defined in Periodic interrupt-do-complete-split. If it is the last complete-split (with a NYET response), then the transfer state of the siTD is not advanced (never received any data) and the Active bit is cleared. No bits are set in the Status field because this is essentially a skipped transaction. The transaction translator must have responded to all the scheduled complete-splits with NYETs, meaning that the start-split issued by the host controller was not received. This result should be interpreted by system software as if the transaction was completely skipped. The test for whether this is the last complete split can be performed by XORing C-mask with C-prog-mask. A zero result indicates that all complete-splits have been executed.

### • MDATA (and Last)

See above description for testing for Last. This can only occur when there is an error condition. Either there has been a babble condition on the full-speed link, which delayed the completion of the full-speed transaction, or software set up the S-mask and/or C-masks incorrectly. The host controller must set the XactErr bit and clear the Active bit.

### • NYET (and not Last)

See above description for testing for Last. The complete-split transaction received a NYET response from the transaction translator. Do not update any transfer state (except for C-prog-mask) and stay in this state.

### MDATA (and not Last)

The transaction translator responds with an MDATA when it has partial data for the split transaction. For example, the full-speed transaction data payload spans from microframe X to X+1 and during microframe X, the transaction translator responds with an MDATA and the data accumulated up to the end of microframe X. The host controller advances the transfer state to reflect the number of bytes received.

If Test A succeeds, but Test B fails, it means that one or more of the complete-splits have been skipped. The host controller sets the Missed Micro-Frame status bit and clears the Active bit.

# 17.6.12.3.6 Complete-split for scheduling boundary cases 2a, 2b

Boundary cases 2a and 2b (INs only) (see Figure 17-58) require that the host controller use the transaction state context of the previous siTD to finish the split transaction. The table below enumerates the transaction state fields.

Table 17-82. Summary siTD split transaction state

| Buffer state                | Status                       | Execution progress |
|-----------------------------|------------------------------|--------------------|
| Total bytes To transfer     | All bits in the status field | C-prog-mask        |
| P (page select)             |                              |                    |
| Current Offset              |                              |                    |
| TP (transaction position)   |                              |                    |
| T-count (transaction count) |                              |                    |

### NOTE

TP and T-count are used only for Host to Device (OUT) endpoints.

If software has budgeted the schedule of this data stream with a frame wrap case, then it must initialize the siTD[Back Pointer] field to reference a valid siTD and have the T bit in the siTD[Back Pointer] field cleared. Otherwise, software must set the T bit in siTD[Back Pointer]. The host controller's rules for interpreting when to use the siTD[Back Pointer] field are listed below. These rules apply only when the siTD's Active bit is a one and the SplitXState is Do Complete Split.

- When cMicroFrameBit is a 0x1 and the siTD<sub>X</sub>[Back Pointer] T-bit is zero, or
- If cMicroFrameBit is a 0x2 and siTD<sub>X</sub>[S-mask[0]] is zero

When either of these conditions apply, then the host controller must use the transaction state from  $siTD_{X-1}$ .

In order to access  $siTD_{X-1}$ , the host controller reads on-chip the siTD referenced from  $siTD_X[Back\ Pointer]$ .

The host controller must save the entire state from  $siTD_X$  while processing  $siTD_{X-1}$ . This is to accommodate for case 2b processing. The host controller must not recursively walk the list of  $siTD[Back\ Pointers]$ .

If  $siTD_{X-1}$  is active (Active bit is set and SplitXStat is Do Complete Split), then both Test A and Test B are applied as described above. If these criteria to execute a complete-split are met, the host controller executes the complete split and evaluates the results as described above. The transaction state (see Table 17-82) of  $siTD_{X-1}$  is appropriately advanced based on the results and written back to memory. If the resultant state of  $siTD_{X-1}$ 's Active bit is a one, then the host controller returns to the context of  $siTD_X$ , and follows its next pointer to the next schedule item. No updates to  $siTD_X$  are necessary.

If  $siTD_{X-1}$  is active (Active bit is set and SplitXStat is Do Start Split), then the host controller must clear the Active bit and set the Missed Micro-Frame status bit and the resultant status is written back to memory.

If  $siTD_{X-1}$ 's Active bit is cleared, (because it was cleared when the host controller first visited  $siTD_{X-1}$  via  $siTD_X$ 's back pointer, it transitioned to zero as a result of a detected error, or the results of  $siTD_{X-1}$ 's complete-split transaction cleared it), then the host controller returns to the context of  $siTD_X$  and transitions its SplitXState to Do Start Split. The host controller then determines whether the case 2b start split boundary condition exists (that is, if cMicroframeBit is 1 and  $siTD_X[S-mask[0]]$  is 1). If this criterion is met the host controller immediately executes a start-split transaction and appropriately advances the transaction state of  $siTD_X$ , then follows  $siTD_X[Next\ Pointer]$  to the next schedule item. If the criterion is not met, the host controller simply follows  $siTD_X[Next\ Pointer]$  to the next schedule item. Note that in the case of a 2b boundary case, the split-transaction of  $siTD_{X-1}$  will have its Active bit cleared when the host controller returns to the context of  $siTD_X$ . Also, note that software should not initialize an siTD with C-mask bits 0 and 1 set and an S-mask with bit 0 set. This scheduling combination is not supported and the behavior of the host controller is undefined.

# 17.6.12.3.7 Split transaction for isochronous-processing example

There is an important difference between how the hardware/software manages the isochronous split transaction state machine and how it manages the asynchronous and interrupt split transaction state machines.

The asynchronous and interrupt split transaction state machines are encapsulated within a single queue head. The progress of the data stream depends on the progress of each split transaction. In some respects, the split-transaction state machine is sequenced using the Execute Transaction queue head traversal state machine.

Isochronous is a pure time-oriented transaction/data stream. The interface data structures are optimized to efficiently describe transactions that need to occur at specific times. The isochronous split-transaction state machine must be managed across these time-oriented data structures. This means that system software must correctly describe the scheduling of split-transactions across more than one data structure.

Then the host controller must make the appropriate state transitions at the appropriate times, in the correct data structures.

For example, the table below illustrates a few frames worth of scheduling required to schedule a case 2a full-speed isochronous data stream.

Table 17-83. Example case 2a-software scheduling siTDs for an IN endpoint

| siTD <sub>X</sub> |       |   |   |   | Micro- | frames |   |   |   | InitialSplitXState |
|-------------------|-------|---|---|---|--------|--------|---|---|---|--------------------|
| #                 | Masks | 0 | 1 | 2 | 3      | 4      | 5 | 6 | 7 |                    |

Table continues on the next page...

Table 17-83. Example case 2a-software scheduling siTDs for an IN endpoint (continued)

| siTD <sub>X</sub> |        |   |   |    | Micro-    | frames    |      |   |   | InitialSplitXState |
|-------------------|--------|---|---|----|-----------|-----------|------|---|---|--------------------|
| Х                 | S-mask |   |   |    |           | 1         |      |   |   | Do start split     |
|                   | C-mask | 1 | 1 |    |           |           |      | 1 | 1 |                    |
| X+1               | S-mask |   |   |    |           | 1         |      |   |   | Do complete split  |
|                   | C-mask | 1 | 1 |    |           |           |      | 1 | 1 |                    |
| X+2               | S-mask |   |   |    |           | 1         |      |   |   | Do complete split  |
|                   | C-mask | 1 | 1 |    |           |           |      | 1 | 1 |                    |
| X+3               | S-mask |   |   | Re | peats pre | vious pat | tern | • |   | Do complete split  |
|                   | C-mask |   |   |    |           |           |      |   |   |                    |

This example shows the first three siTDs for the transaction stream. Since this is the case-2a frame-wrap case, S-masks of all siTDs for this endpoint have a value of 0x10 (a one bit in microframe 4) and C-mask value of 0xC3 (one-bits in microframes 0,1, 6 and 7). Additionally, software ensures that the Back Pointer field of each siTD references the appropriate siTD data structure (and the Back Pointer T-bits are cleared).

The initial SplitXState of the first siTD is Do Start Split. The host controller will visit the first siTD eight times during frame X. The C-mask bits in microframes 0 and 1 are ignored because the state is Do Start Split. During microframe 4, the host controller determines that it can run a start-split (and does) and changes SplitXState to Do Complete Split. During microframes 6 and 7, the host controller executes complete-splits. Notice the siTD for frame X+1 has it's SplitXState initialized to Do Complete Split. As the host controller continues to traverse the schedule during H-Frame X+1, it will visit the second siTD eight times. During microframes 0 and 1 it will detect that it must execute complete-splits.

During H-Frame X+1, microframe 0, the host controller detects that  $siTD_{X+1}$ 's Back Pointer[T] bit is a zero, saves the state of  $siTD_{X+1}$  and fetches  $siTD_X$ . It executes the complete split transaction using the transaction state of  $siTD_X$ . If the  $siTD_X$  split transaction is complete, siTD's Active bit is cleared and results written back to  $siTD_X$ . The host controller retains the fact that  $siTD_X$  is retired and transitions the SplitXState in  $siTD_{X+1}$  to Do Start Split. At this point, the host controller is prepared to execute the start-split for  $siTD_{X+1}$  when it reaches microframe 4. If the split-transaction completes early (transaction-complete is defined in Periodic isochronous-do complete split), that is, before all the scheduled complete-splits have been executed, the host controller changes  $siTD_X[SplitXState]$  to Do Start Split early and naturally skips the remaining scheduled complete-split transactions. For this example,  $siTD_{X+1}$  does not receive a DATA0 response until H-Frame X+2, microframe 1.

During H-Frame X+2, microframe 0, the host controller detects that  $siTD_{X+2}$ 's Back Pointer[T] bit is zero, saves the state of  $siTD_{X+2}$  and fetches  $siTD_{X+1}$ . As described above, it executes another split transaction, receives an MDATA response, updates the transfer state, but does not modify the Active bit. The host controller returns to the context of  $siTD_{X+2}$ , and traverses it's next pointer without any state change updates to  $siTD_{X+2}$ .

During H-Frame X+2, microframe 1, the host controller detects  $siTD_{X+2}$ 's S-mask[0] bit is zero, saves the state of  $siTD_{X+2}$  and fetches  $siTD_{X+1}$ . It executes another complete-split transaction, receives a DATA0 response, updates the transfer state and clears the Active bit. It returns to the state of  $siTD_{X+2}$  and changes its SplitXState to Do Start Split. At this point, the host controller is prepared to execute start-splits for  $siTD_{X+2}$  when it reaches microframe 4.

### 17.6.13 Port test modes

EHCI host controllers implement the port test modes Test J\_State, Test K\_State, Test\_Packet, Test Force\_Enable, and Test SE0\_NAK as described in the *USB Specification Revision 2.0*.

The required, port test sequence, assuming the CF-bit in the CONFIGFLAG register is set, is as follows:

- 1. Disable the periodic and asynchronous schedules by clearing the USBCMD[ASE] and USBCMD[PSE].
- 2. Place all enabled root ports into the suspended state by setting the Suspend bit in the PORTSC register (PORTSC[SUSP]).
- 3. Clear USBCMD[RS] (run/stop) and wait for USBSTS[HCH] to transition to a one. In Device mode, the Test Mode starts only if Run/Stop bit is set to 1. In Host mode, the Test Mode starts regardless of Run/Stop bit.
- 4. Set the Port Test Control field in the port under test PORTSC register to the value corresponding to the desired test mode. If the selected test is Test\_Force\_Enable, then USBCMD[RS] must then be transitioned back to one, in order to enable transmission of SOFs out of the port under test.
- 5. When the test is complete, system software must ensure the host controller is halted (HCH bit is a one) then it terminates and exits test mode by setting USBCMD[RST].

# 17.6.14 Interrupts

The EHCI host controller hardware provides interrupt capability based on a number of sources.

#### **Host operations**

The following list describes the general groups of interrupt sources:

- Interrupts as a result of executing transactions from the schedule (success and error conditions)
- Host controller events (Port change events, and so on)
- Host controller error events

All transaction-based sources are maskable through the host controller's Interrupt Enable register (USBINTR). Additionally, individual transfer descriptors can be marked to generate an interrupt on completion. This section describes each interrupt source and the processing that occurs in response to the interrupt.

During normal operation, interrupts may be immediate or deferred until the next interrupt threshold occurs. The interrupt threshold is a tunable parameter via the interrupt threshold control field in the USBCMD register. The value of this register controls when the host controller generates an interrupt on behalf of normal transaction execution. When a transaction completes during an interrupt interval period, the interrupt signaling the completion of the transfer will not occur until the interrupt threshold occurs. For example, the default value is eight microframes. This means that the host controller will not generate interrupts any more frequently than once every eight microframes.

Host system error details effects of a host system error.

If an interrupt has been scheduled to be generated for the current interrupt threshold interval, the interrupt is not signaled until after the status for the last complete transaction in the interval has been written back to system memory. This may sometimes result in the interrupt not being signaled until the next interrupt threshold.

Initial interrupt processing is the same, regardless of the reason for the interrupt. When an interrupt is signaled by the hardware, CPU control is transferred to host controller's USB interrupt handler. The precise mechanism to accomplish the transfer is OS specific. For this discussion it is just assumed that control is received. When the interrupt handler receives control, its first action is to reads the USBSTS. It then acknowledges the interrupt by clearing all of the interrupt status bits by writing ones to these bit positions. The handler then determines whether the interrupt is due to schedule processing or some other event. After acknowledging the interrupt, the handler (via an OS-specific mechanism), schedules a deferred procedure call (DPC) which will execute later. The DPC routine processes the results of the schedule execution. The precise mechanisms used are beyond the scope of this document.

#### NOTE

The only method software should use for acknowledging an interrupt is by transitioning the appropriate status bits in the USBSTS register from a one to a zero.

# 17.6.14.1 Transfer/transaction based interrupts

These interrupt sources are associated with transfer and transaction progress. They are all dependent on the next interrupt threshold.

### 17.6.14.1.1 Transaction error

A transaction error is any error that caused the host controller to think that the transfer did not complete successfully.

The table below lists the events/responses that the host can observe as a result of a transaction. The effects of the error counter and interrupt status are summarized in the following paragraphs. Most of these errors set the XactErr status bit in the appropriate interface data structure.

| Event/ Result        |      | Queue Head/qTD/iTD/siTD Side Effects | USBSTS[USBERRINT] |
|----------------------|------|--------------------------------------|-------------------|
|                      | Cerr | Status Field                         |                   |
| CRC                  | -1   | XactErr set                          | 1 <sup>1</sup>    |
| Timeout              | -1   | XactErr set                          | 11                |
| Bad PID <sup>2</sup> | -1   | XactErr set                          | 11                |
| Babble               | N/A  | See Serial bus babble                | 1                 |
| Buffer Error         | N/A  | See Data buffer error                |                   |

Table 17-84. Summary of transaction errors

There is a small set of protocol errors that relate only when executing a queue head and fit under the umbrella of a WRONG PID error that are significant to explicitly identify. When these errors occur, the XactErr status bit in the queue head is set and the Cerr field is decremented. When the PID Code indicates a SETUP, the following responses are protocol errors and result in XactErr bit being set and the Cerr field being decremented.

- EPS field indicates a high-speed device and it returns a Nak handshake to a SETUP.
- EPS field indicates a high-speed device and it returns a Nyet handshake to a SETUP.
- EPS field indicates a low- or full-speed device and the complete-split receives a Nak handshake.

<sup>&</sup>lt;sup>1</sup> If occurs in a queue head, then USBERRINT is asserted only when Cerr counts down from a one to a zero. In addition the queue is halted.

<sup>&</sup>lt;sup>2</sup> The host controller received a response from the device, but it could not recognize the PID as a valid PID.

### 17.6.14.1.2 Serial bus babble

When a device transmits more data on the USB than the host controller is expecting for this transaction, it is defined to be babbling.

In general, this is called a packet babble. When a device sends more data than the maximum length number of bytes, the host controller sets the babble detected bit to a one and halts the endpoint if it is using a queue head. Maximum length is defined as the minimum of total bytes to transfer and maximum packet size. The Cerr field is not decremented for a packet babble condition (only applies to queue heads).

A babble condition also exists if IN transaction is in progress at High-speed EOF2 point. This is called a frame babble. A frame babble condition is recorded into the appropriate schedule data structure. In addition, the host controller must disable the port to which the frame babble is detected.

USBSTS[UEI] (USB error interrupt) is set and if the USBINTR[UEE] (USB error interrupt enable) is set, then a hardware interrupt is signaled to the system at the next interrupt threshold. The host controller will never start an OUT transaction that babbles across a microframe EOF.

### NOTE

When a host controller detects a data PID mismatch, it must either: disable the packet babble checking for the duration of the bus transaction or do packet babble checking based solely on Maximum Packet Size. The USB core specification defines the requirements on a data receiver when it receives a data PID mismatch (for example, expects a DATA0 and gets a DATA1 or visa-versa). In summary, it must ignore the received data and respond with an ACK handshake, in order to advance the transmitter's data sequence. The EHCI interface allows system software to provide buffers for a Control, Bulk or Interrupt IN endpoint that are not an even multiple of the maximum packet size specified by the device. Whenever a device misses an ACK for an IN endpoint, the host and device are out of synchronization with respect to the progress of the data transfer. The host controller may have advanced the transfer to a buffer that is less than maximum packet size. The device re-sends its maximum packet size data packet, with the original data PID, in response to the next IN token. In order to properly manage the bus protocol, the host controller must disable the packet babble check when it observes the data PID mismatch.

### 17.6.14.1.3 Data buffer error

This event indicates that an overrun of incoming data or a underrun of outgoing data has occurred for this transaction.

This would generally be caused by the host controller not being able to access required data buffers in memory within necessary latency requirements. These conditions are not considered transaction errors, and do not effect the error count in the queue head. When these errors do occur, the host controller records the fact the error occurred by setting the Data Buffer Error bit in the queue head, iTD or siTD.

If the data buffer error occurs on a non-isochronous IN, the host controller will not issue a handshake to the endpoint. This forces the endpoint to resend the same data (and data toggle) in response to the next IN to the endpoint.

If the data buffer error occurs on an OUT, the host controller must corrupt the end of the packet so that it cannot be interpreted by the device as a good data packet. Simply truncating the packet is not considered acceptable. An acceptable implementation option is to 1's complement the CRC bytes and send them. There are other options suggested in the transaction translator section of the *USB Specification Revision 2.0*.

# 17.6.14.1.4 USB interrupt (interrupt on completion (IOC))

Transfer descriptors (iTDs, siTDs, and queue heads (qTDs)) contain a bit that can be set to cause an interrupt on their completion.

The completion of the transfer associated with that schedule item causes USBSTS[UI] (USB interrupt) to be set. In addition, if a short packet is encountered on an IN transaction associated with a queue head, then this event also causes USBINT to be set. If USBINTR[UE] (USB interrupt enable) is set, a hardware interrupt is signaled to the system at the next interrupt threshold. If the completion is because of errors, USBSTS[UEI] (USB error interrupt) is also set.

# 17.6.14.1.5 Short packet

Reception of a data packet that is less than the endpoint's Max Packet size during Control, Bulk or Interrupt transfers signals the completion of the transfer.

Whenever a short packet completion occurs during a queue head execution, USBSTS[UI] (USB interrupt bit) is set. If the USB interrupt enable bit is set (USBINTR[UE]), a hardware interrupt is signaled to the system at the next interrupt threshold.

# 17.6.14.2 Host controller event interrupts

These interrupt sources are independent of the interrupt threshold (with the one exception being the Interrupt on Async Advance.

# 17.6.14.2.1 Port change events

Port registers contain status and status change bits.

When the status change bits are set, the host controller sets the USBSTS[PCI]. If the port change interrupt enable bit (PCE) in the USBINTR register is set, the host controller issues a hardware interrupt. The port status change bits in PORTSC include:

- Connect change status (CSC)
- Port enable/disable change (PEC)
- Over-current change (OCC)
- Force port resume (FPR)

### 17.6.14.2.2 Frame list rollover

This event indicates that the host controller has wrapped the frame list.

The current programmed size of the frame list effects how often this interrupt occurs. If the frame list size is 1024, then the interrupt occurs every 1024 milliseconds, if it is 512, then it occurs every 512 milliseconds, and so on. When a frame list rollover is detected, the host controller sets the frame list rollover bit, USBSTS[FRI]. If USBINTR[FRE] is set (frame list rollover enable), the host controller issues a hardware interrupt. This interrupt is not delayed to the next interrupt threshold.

# 17.6.14.2.3 Interrupt on async advance

This event is used for deterministic removal of queue heads from the asynchronous schedule.

Whenever the host controller advances the on-chip context of the asynchronous schedule, it evaluates the value of USBCMD[IAA]. If it is set, it sets USBSTS[AAI]. If USBINTR[AAE] is set, the host controller issues a hardware interrupt at the next interrupt threshold. A detailed explanation of this feature is described in Removing queue heads from asynchronous schedule.

# 17.6.14.2.4 Host system error

The host controller is a bus master and any interaction between the host controller and the system may experience errors.

The type of host error may be catastrophic to the host controller making it impossible for the host controller to continue in a coherent fashion. Behavior for these types of errors is to halt the host controller. Host-based error must result in the following actions:

- USBCMD[RS] is cleared.
- USBSTS[SEI] and USBSTS[HCH] register are set
- If the host system error enable bit, USBINTR[SEE] is set, the host controller issues a hardware interrupt. This interrupt is not delayed to the next interrupt threshold.

The table below summarizes the required actions taken on the various host errors.

| Cycle type                      | Master abort | Target abort | Data phase parity |
|---------------------------------|--------------|--------------|-------------------|
| Frame list pointer fetch (read) | Fatal        | Fatal        | Fatal             |
| siTD fetch (read)               | Fatal        | Fatal        | Fatal             |
| siTD status write-back (write)  | Fatal        | Fatal        | Fatal             |
| iTD fetch (read)                | Fatal        | Fatal        | Fatal             |
| iTD status write-back (write)   | Fatal        | Fatal        | Fatal             |
| qTD fetch (read)                | Fatal        | Fatal        | Fatal             |
| qHD status write-back (write)   | Fatal        | Fatal        | Fatal             |
| Data write                      | Fatal        | Fatal        | Fatal             |
| Data read                       | Fatal        | Fatal        | Fatal             |

Table 17-85. Summary behavior on host system errors

### NOTE

After a host system error, software must reset the host controller using USBCMD[RST] before re-initializing and restarting the host controller.

# 17.7 Device data structures

This section defines the interface data structures used to communicate control, status, and data between device controller driver (DCD) software and the device controller. The data structure definitions in this chapter support a 32-bit memory buffer address space. The interface consists of device queue heads and transfer descriptors.

#### NOTE

Software must ensure that no interface data structure reachable by the device controller spans a 4K-page boundary.

The data structures defined in the section are (from the device controller's perspective) a mix of read-only and read/writable fields. The device controller must preserve the read-only fields on all data structure writes.

### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **Device data structures**

The USB DR module includes DCD software called the USB 2.0 Device API. The device API provides an easy to use Application Program Interface for developing device (peripheral) applications. The device API incorporates and abstracts for the application developer all of the elements of the program interface.



Figure 17-61. Endpoint queue head organization

# 17.7.1 Endpoint queue head

The device endpoint queue head (dQH) is where all transfers are managed.

The dQH is a 48-byte data structure, but must be aligned on 64-byte boundaries. During priming of an endpoint, the dTD (device transfer descriptor) is copied into the overlay area of the dQH, which starts at the nextTD pointer DWord and continues through the end of the buffer pointers DWords. After a transfer is complete, the dTD status DWord is updated in the dTD pointed to by the currentTD pointer. While a packet is in progress, the overlay area of the dQH is used as a staging area for the dTD so that the Device Controller can access needed information with little minimal latency.

The figure below shows the endpoint queue head structure.

Table 17-86. Endpoint queue head layout

| 3<br>1                                              | 3                                                   | 2<br>9 | 2<br>8 | -    | -    | 2<br>5 | 2<br>4 | 2 | 2 | 2 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6            | 15 | 14 | 1 | 1<br>2 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 | offset |
|-----------------------------------------------------|-----------------------------------------------------|--------|--------|------|------|--------|--------|---|---|---|--------|--------|--------|--------|-------------------|----|----|---|--------|----|----|---|---|---|---|---|-----|-----|---|---|---|--------|
| Mult zlt 00 Maximum Packet Length ios 000_0000_0000 |                                                     |        |        |      |      |        |        |   |   |   |        |        |        |        | 0x00              |    |    |   |        |    |    |   |   |   |   |   |     |     |   |   |   |        |
| С                                                   | urre                                                | nt d   | TD I   | Poir | ntei | r1     |        |   |   |   |        |        |        |        |                   |    |    |   |        |    |    |   |   |   |   |   | 0_0 | 000 | 0 |   |   | 0x04   |
| Ν                                                   | Next dTD Pointer <sup>1</sup> 0000 T <sup>1</sup> 0 |        |        |      |      |        |        |   |   |   |        |        |        |        | 0x08 <sup>2</sup> |    |    |   |        |    |    |   |   |   |   |   |     |     |   |   |   |        |

Table continues on the next page...

Table 17-86. Endpoint queue head layout (continued)

| 0 Total Bytes <sup>1</sup>           | ioc <sup>1</sup> | 000 | MultO <sup>1</sup> | 00                | Status <sup>1</sup> | 0x0C <sup>2</sup> |
|--------------------------------------|------------------|-----|--------------------|-------------------|---------------------|-------------------|
| Buffer Pointer (Page 0) <sup>1</sup> |                  |     | Current            | 0x10 <sup>2</sup> |                     |                   |
| Buffer Pointer (Page 1) <sup>1</sup> |                  |     | Reserve            | 0x14 <sup>2</sup> |                     |                   |
| Buffer Pointer (Page 2) <sup>1</sup> |                  |     | Reserve            | ed                |                     | 0x18 <sup>2</sup> |
| Buffer Pointer (Page 3) <sup>1</sup> |                  |     | Reserve            | 0x1C <sup>2</sup> |                     |                   |
| Buffer Pointer (Page 4) <sup>1</sup> |                  |     | Reserve            | ed                | 0x20 <sup>2</sup>   |                   |
| Reserved                             |                  |     |                    |                   |                     | 0x24              |
| Setup Buffer Bytes 3-0 <sup>1</sup>  |                  |     |                    |                   |                     | 0x28              |
| Setup Buffer Bytes 7-4 <sup>1</sup>  |                  |     |                    |                   |                     | 0x2C              |

- 1. Device controller read/write; all others read-only.
- 2. Offsets 0x08 through 0x20 contain the transfer overlay.

# 17.7.1.1 Endpoint capabilities/characteristics

This DWord specifies static information about the endpoint, in other words, this information does not change over the lifetime of the endpoint.

Device controller software should not attempt to modify this information while the corresponding endpoint is enabled.

The table below describes the endpoint capabilities and characteristics fields.

Table 17-87. Endpoint capabilities/characteristics

| Bits  | Name | Description                                                                                                                                                                                                              |
|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30 | Mult | Mult. This field is used to indicate the number of packets executed per transaction description as given by the following:                                                                                               |
|       |      | 00 - Execute N Transactions as demonstrated by the USB variable length packet protocol where N is computed using the Maximum Packet Length (dQH) and the Total Bytes field (dTD)                                         |
|       |      | 01 Execute 1 Transaction.                                                                                                                                                                                                |
|       |      | 10 Execute 2 Transactions.                                                                                                                                                                                               |
|       |      | 11 Execute 3 Transactions.                                                                                                                                                                                               |
|       |      | NOTE: Non-ISO endpoints must set Mult = 00. NOTE: ISO endpoints must set Mult = 01, 10, or 11 as needed.                                                                                                                 |
| 29    | zlt  | Zero length termination select. This bit is used to indicate when a zero length packet is used to terminate transfers where the total transfer length is a multiple. This bit is not relevant for Isochronous transfers. |
|       |      | 0 Enable zero length packet to terminate transfers equal to a multiple of the Maximum Packet Length. (default).                                                                                                          |
|       |      | 1 Disable the zero length packet on transfers that are equal in length to a multiple Maximum Packet Length.                                                                                                              |
| 28-27 | -    | Reserved, should be cleared. These bit reserved for future use and should be cleared.                                                                                                                                    |

Table continues on the next page...

Table 17-87. Endpoint capabilities/characteristics (continued)

| Bits  | Name                        | Description                                                                                                                                                                        |
|-------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26-16 | Maximum<br>Packet<br>Length | Maximum packet length. This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize). The maximum value this field may contain is 0x400 (1024). |
| 15    | ios                         | Interrupt on setup (IOS). This bit is used on control type endpoints to indicate if USBINT is set in response to a setup being received.                                           |
| 14-0  | -                           | Reserved, should be cleared. Bits reserved for future use and should be cleared.                                                                                                   |

# 17.7.1.2 Transfer overlay

The seven DWords in the overlay area represent a transaction working space for the device controller.

The general operational model is that the device controller can detect whether the overlay area contains a description of an active transfer. If it does not contain an active transfer, then it will not read the associated endpoint.

After an endpoint is read, the dTD is copied into this queue head overlay area by the device controller. Until a transfer is expired, software must not write the queue head overlay area or the associated transfer descriptor. When the transfer is complete, the device controller will write the results back to the original transfer descriptor and advance the queue.

See dTD for a description of the overlay fields.

# 17.7.1.3 Current dTD pointer

The current dTD pointer is used by the device controller to locate the transfer in progress.

This word is for USB\_DR controller (hardware) use only and should not be modified by DCD software.

The table below describes the current dTD pointer fields.

Table 17-88. Current dTD pointer

| Bits | Description                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Current dtd. This field is a pointer to the dTD that is represented in the transfer overlay area. This field is modified by the Device Controller to next dTD pointer during endpoint priming or queue advance. |
| 4-0  | Reserved, should be cleared. Bit reserved for future use and should be cleared.                                                                                                                                 |

# 17.7.1.4 Setup buffer

The setup buffer is dedicated storage for the 8-byte data that follows a setup PID.

### NOTE

Each endpoint has a TX and an RX dQH associated with it, and only the RX queue head is used for receiving setup data packets.

The table below describes the multiple mode control fields.

Table 17-89. Multiple mode control

| DWor<br>d | Bits | Description                                                                                                                                          |
|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         |      | Setup Buffer 0. This buffer contains bytes 3 to 0 of an incoming setup buffer packet and is written by the device controller to be read by software. |
| 2         |      | Setup Buffer 1. This buffer contains bytes 7 to 4 of an incoming setup buffer packet and is written by the device controller to be read by software. |

# 17.7.2 Endpoint transfer descriptor (dTD)

The dTD describes the location and quantity of data to be sent/received for given transfer to the device controller.

The DCD should not attempt to modify any field in an active dTD except the Next Link Pointer, which should only be modified as described in Managing transfers with transfer descriptors.

The figure below shows the endpoint transfer descriptor.

Table 17-90. Endpoint transfer descriptor (dTD)

| 31   | 30                      | 29    | 28    | 27             | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18             | 17  | 16   | 15   | 14  | 13  | 12 | 11                          | 10   | 9   | 8   | 7    | 6    | 5    | 4 | 3    | 2 | 1 | 0 | offset |
|------|-------------------------|-------|-------|----------------|-----|----|----|----|----|----|----|----|----------------|-----|------|------|-----|-----|----|-----------------------------|------|-----|-----|------|------|------|---|------|---|---|---|--------|
| Nex  | lext Link Pointer       |       |       |                |     |    |    |    |    |    |    |    |                |     |      | 0000 |     |     |    |                             |      |     |     |      |      |      |   | 0x00 |   |   |   |        |
| 0    | To                      | tal E | 3yte  | s <sup>1</sup> |     |    |    |    |    |    |    |    |                |     |      | ioc  | 000 | )   |    | Mu                          | ltO  | 00  |     | Sta  | atus | 1    |   |      |   |   |   | 0x04   |
| Buff | er F                    | oin   | ter ( | Pag            | e 0 | )  |    |    |    |    |    |    |                |     |      |      |     |     |    | Current Offset <sup>1</sup> |      |     |     |      |      |      |   |      |   |   |   | 0x08   |
| Buff | er F                    | oin   | ter ( | Pag            | e 1 | )  |    |    |    |    |    |    |                |     |      |      |     |     |    | 0 Frame Number <sup>1</sup> |      |     |     |      |      |      |   |      |   |   |   | 0x0C   |
| Buff | er F                    | oin   | ter ( | Pag            | e 2 | )  |    |    |    |    |    |    |                |     |      |      |     |     |    | 000                         | 00_0 | 000 | 0_0 | 000  |      |      |   |      |   |   |   | 0x10   |
| Buff | Buffer Pointer (Page 3) |       |       |                |     |    |    |    |    |    |    |    |                | 000 | 00_0 | 000  | 0_0 | 000 |    |                             |      |     |     |      |      | 0x14 |   |      |   |   |   |        |
| Buff | Buffer Pointer (Page 4) |       |       |                |     |    |    |    |    |    |    |    | 0000_0000_0000 |     |      |      |     |     |    |                             |      |     |     | 0x18 |      |      |   |      |   |   |   |        |

1. Device controller read/write; all others read-only.

#### **Device data structures**

The table below describes the next dTD pointer fields.

### Table 17-91. Next dTD pointer

| Bits | Description                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5 | Next transfer element pointer. This field contains the physical memory address of the next dTD to be processed. The field corresponds to memory address signals [31:5], respectively.                   |
| 4-1  | Reserved, should be cleared. Bits reserved for future use and should be cleared.                                                                                                                        |
| 0    | Terminate (T). 1=pointer is invalid. 0=Pointer is valid (points to a valid Transfer Element Descriptor). This bit indicates to the Device Controller that there are no more valid entries in the queue. |

The table below describes the next dTD token fields.

### Table 17-92. dTD token

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31    | Reserved, should be cleared. Bit reserved for future use and should be cleared.                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 30-16 | Total Bytes. This field specifies the total number of bytes to be moved with this transfer descriptor. This field is decremented by the number of bytes actually moved during the transaction and only on the successful completion of the transaction.                                                                                                                                                                             |  |  |  |  |
|       | The maximum value software may store in the field is 5*4K(5000H). This is the maximum number of bytes 5 page pointers can access. Although it is possible to create a transfer up to 20K this assumes the 1st offset into the first page is 0. When the offset cannot be predetermined, crossing past the 5th page can be guaranteed by limiting the total bytes to 16K. Therefore, the maximum recommended transfer is 16K(4000H). |  |  |  |  |
|       | If the value of the field is zero when the controller fetches this transfer descriptor (and the active bit is set), the device controller executes a zero-length transaction and retires the transfer descriptor.                                                                                                                                                                                                                   |  |  |  |  |
|       | It is not a requirement for IN transfers that Total Bytes To Transfer be a multiple of Maximum Packet Length. If software builds such a transfer descriptor for an IN transfer, the last transaction will always be less that Maximum Packet Length.                                                                                                                                                                                |  |  |  |  |
| 15    | Interrupt On Complete (IOC). This bit is used to indicate if USBINT is to be set in response to device controller being finished with this dTD.                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 14-12 | Reserved, should be cleared. Bits reserved for future use and should be cleared.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 11-10 | Multiplier Override (MultO). This field can be used for transmit ISO's (that is, ISO-IN) to override the multiplier in the QH. This field must be zero for all packet types that are not transmit-ISO.                                                                                                                                                                                                                              |  |  |  |  |
|       | Example:                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|       | if QH.multiplier = 3; Maximum packet size = 8; Total bytes = 15; MultiO = 0 [default]                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|       | Three packets are sent: {Data2(8); Data1(7); Data0(0)}                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|       | if QH.multiplier = 3; Maximum packet size = 8; Total bytes = 15; MultiO = 2                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|       | Two packets are sent: {Data1(8); Data0(7)}                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|       | For maximal efficiency, software should compute MultO = greatest integer of (Total Bytes/Max. Packet Size) except for the case when Total bytes = 0; then MultO should be 1.                                                                                                                                                                                                                                                        |  |  |  |  |
|       | NOTE: Non-ISO and non-TX endpoints must set MultO = 00.                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 9-8   | Reserved, should be cleared. Bits reserved for future use and should be cleared.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |

Table continues on the next page...

# Table 17-92. dTD token (continued)

| Bits | Description                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7-0  | Status. This field is used by the Device Controller to communicate individual command execution states back to the Device Controller software. This field contains the status of the last transaction performed on this qTD. The bit encodings are: |  |  |  |  |  |  |
|      | Bit Status Field Description                                                                                                                                                                                                                        |  |  |  |  |  |  |
|      | 7 Active                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|      | 6 Halted                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|      | 5 Data Buffer Error                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|      | 3 Transaction Error                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|      | 4,2,0 Reserved, should be cleared                                                                                                                                                                                                                   |  |  |  |  |  |  |

The following tables describe the buffer pointer page n fields.

# Table 17-93. Buffer pointer page 0

| Bits | Description                                                                                                                                                                      |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|      | Buffer Pointer. Selects the page offset in memory for the packet buffer. Non virtual memory systems will typically set the buffer pointers to a series of incrementing integers. |  |  |  |
| 11-0 | Current Offset. Offset into the 4kb buffer where the packet is to begin.                                                                                                         |  |  |  |

# Table 17-94. Buffer pointer page 1

| Bits | Description                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Buffer Pointer. Selects the page offset in memory for the packet buffer. Non virtual memory systems will typically set the buffer pointers to a series of incrementing integers.                        |
| 11   | Reserved                                                                                                                                                                                                |
|      | Frame Number. Written by the device controller to indicate the frame number in which a packet finishes. This is typically be used to correlate relative completion times of packets on an ISO endpoint. |

### Table 17-95. Buffer pointer pages 2-4

| Bits | Description                                                                                                                                                                      |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|      | Buffer Pointer. Selects the page offset in memory for the packet buffer. Non virtual memory systems will typically set the buffer pointers to a series of incrementing integers. |  |  |  |
| 11-0 | Reserved                                                                                                                                                                         |  |  |  |

# 17.8 Device operational model

The function of the device operation is to transfer a request in the memory image to and from the Universal Serial Bus. Using a set of linked list transfer descriptors, pointed to by a queue head, the device controller will perform the data transfers. The following sections explain the use of the device controller from the device controller driver (DCD) point-of-view and further describe how specific USB bus events relate to status changes in the device controller programmer's interface.

### 17.8.1 Device controller initialization

After hardware reset, the USB DR module is disabled until the run/stop bit (USBCMD[RS]) is set to a '1'.

In the disabled state, the pull-up on the USB D+ is not active which prevents an attach event from occurring. At a minimum, it is necessary to have the queue heads setup for endpoint zero before the device attach occurs. Shortly after the device is enabled, a USB reset will occur followed by setup packet arriving at endpoint 0. A queue head must be prepared so that the device controller can store the incoming setup packet.

To configure the external ULPI PHY the following initialization sequence is required.

- 1. After power-on reset the UTMI PHY will be in disabled state and the PLL will be held reset. The UTMI PHY should remain disabled if the ULPI is being used.
- 2. Set the CONTROL[PHY\_CLK\_SEL] bits to select the ULPI PHY as the source of USB controller PHY clock.
- 3. Wait for PHY clock to become valid. This can be determined by polling the CONTROL[PHY\_CLK\_VALID] status bit. Note that this bit is not valid once the CONTROL[USB\_EN] bit is set.

Once the PHY clock is valid the user can proceed to the device controller initialization phase.

In order to initialize a device, the software should perform the following steps:

1. Set the controller mode to device mode. Optionally set USBMODE[SDIS] (streaming disable).

#### NOTE

Transitioning from host mode to device mode requires a device controller reset before modifying USBMODE.

- 2. Optionally modify the BURSTSIZE register.
- 3. Program PORTSC[PTS] if using a non-ULPI PHY.

- 4. Set CONTROL[USB\_EN]
- 5. Allocate and initialize device queue heads in system memory Minimum: Initialize device queue heads 0 Tx and 0 Rx.

### NOTE

All device queue heads must be initialized for control endpoints before the endpoint is enabled. Device queue heads for non-control endpoints must be initialized before the endpoint can be used.

For information on device queue heads, refer to Device data structures.

6. Configure the ENDPOINTLISTADDR pointer.

For additional information on ENDPOINTLISTADDR, refer to the register table.

7. Enable the microprocessor interrupt associated with the USB DR module and optionally change setting of USBCMD[ITC].

Recommended: enable all device interrupts including: USBINT, USBERRINT, Port Change Detect, USB Reset Received, DCSuspend.

For a list of available interrupts refer to the USBINTR and the USBSTS register tables.

8. Set USBCMD[RS] to run mode.

After the run bit is set, a device reset will occur. The DCD must monitor the reset event and set the DEVICEADDR register, set the ENDPTCTRLx registers, and adjust the software state as described in Bus reset.

#### NOTE

Endpoint 0 is designed as a control endpoint only and does not need to be configured using ENDPTCTRL0 register.

It is also not necessary to initially prime Endpoint 0 because the first packet received will always be a setup packet. The contents of the first setup packet will require a response in accordance with USB device framework command set.

### 17.8.2 Port state and control

From a chip or system reset, the USB\_DR controller enters the powered state.

#### **Device operational model**

A transition from the powered state to the attach state occurs when the run/stop bit (USBCMD[RS]) is set to a '1'. After receiving a reset on the bus, the port will enter the defaultFS or defaultHS state in accordance with the protocol reset described in Appendix C.2 of the *USB Specification Rev. 2.0*. The figure below depicts the state of a USB 2.0 device.



Figure 17-62. USB 2.0 device states

States Powered, Attach, DefaultFS/HS, SuspendFS/HS are implemented in the USB\_DR controller and are communicated to the DCD using status bits, as shown in the table below:

Table 17-96. Device controller state information bits

| Bits            | Register |
|-----------------|----------|
| DCSuspend (SLI) | USBSTS   |

Table continues on the next page...

Table 17-96. Device controller state information bits (continued)

| Bits                     | Register |
|--------------------------|----------|
| USB Reset Received (URI) | USBSTS   |
| Port Change Detect (PCI) | USBSTS   |
| High-Speed Port          | PORTSC   |

It is the responsibility of the DCD to maintain a state variable to differentiate between the defaultFS/HS state and the address/configured states. Change of state from default to address and the configured states is part of the enumeration process described in the device framework section of the USB 2.0 Specification.

As a result of entering the address state, the device address register (DEVICEADDR) must be programmed by the DCD.

Entry into the configured indicates that all endpoints to be used in the operation of the device have been properly initialized by programming the ENDPTCTRL*n* registers and initializing the associated queue heads.

### 17.8.2.1 Bus reset

A bus reset is used by the host to initialize downstream devices.

When a bus reset is detected, the USB\_DR controller will renegotiate its attachment speed, reset the device address to 0, and notify the DCD by interrupt (assuming the USB reset interrupt enable bit, USBINTR[URE], is set). After a reset is received, all endpoints (except endpoint 0) are disabled and any primed transactions are canceled by the device controller. The concept of priming is clarified below, but the DCD must perform the following tasks when a reset is received:

- 1. Clear all setup token semaphores by reading the ENDPTSETUPSTAT register and writing the same value back to the ENDPTSETUPSTAT register.
- 2. Clear all the endpoint complete status bits by reading the ENDPTCOMPLETE register and writing the same value back to the ENDPTCOMPLETE register.
- 3. Cancel all primed status by waiting until all bits in the ENDPTPRIME are 0 and then writing 0xFFFF FFFF to ENDPTFLUSH.
- 4. Read the reset bit in the PORTSC register (PORTSC[PR]) and make sure that it is still active.
  - A USB reset occurs for a minimum of 3 ms, and the DCD must reach this point in the reset cleanup before end of the reset occurs.
  - If it does not, a hardware reset of the device controller is recommended. A hardware reset can be performed by writing a one to the USB\_DR controller reset bit in (USBCMD[RST]). Note that a hardware reset will cause the device to

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **Device operational model**

- detach from the bus by clearing USBCMD[RS] bit. Thus, the DCD must completely re-initialize the USB\_DR controller after a hardware reset.
- 5. Free all allocated dTDs because they will no longer be executed by the device controller. If this is the first time the DCD is processing a USB reset event, then it is likely that no dTDs have been allocated.

At this time, the DCD may release control back to the OS because no further changes to the device controller are permitted until a Port Change Detect is indicated.

After a Port Change Detect, the device has reached the default state and the DCD can read the PORTSC to determine if the device is operating in FS or HS mode. At this time, the device controller has reached normal operating mode and DCD can begin enumeration according to the USB Chapter 9, Device Framework.

### NOTE

The device DCD may use the FS/HS mode information to determine the bandwidth mode of the device.

In some applications, it may not be possible to enable one or more pipes while in FS mode. Beyond the data rate issue, there is no difference in DCD operation between FS and HS modes.

# 17.8.2.2 Suspend/resume

This section discusses the suspend and resume functions.

# 17.8.2.2.1 Suspend description

In order to conserve power, USB\_DR controller automatically enters the suspended state when no bus traffic has been observed for a specified period.

When suspended, the USB\_DR controller maintains any internal status, including its address and configuration. Attached devices must be prepared to suspend at any time they are powered, regardless of if they have been assigned a non-default address, are configured, or neither. Bus activity may cease due to the host entering a suspend mode of its own. In addition, a USB device shall also enter the suspended state when the hub port it is attached to is disabled.

The USB\_DR controller exits suspend mode when there is bus activity. It may also request the host to exit suspend mode or selective suspend by using electrical signaling to indicate remote wake-up. The ability of a device to signal remote wake-up is optional. The USB\_DR controller is capable of remote wake-up signaling. When the USB\_DR controller is reset, remote wake-up signaling must be disabled.

### 17.8.2.2.2 Suspend operational model

The USB\_DR controller moves into the suspend state when suspend signaling is detected or activity is missing on the upstream port for more than a specific period.

After the device controller enters the suspend state, the DCD is notified by an interrupt (assuming DC Suspend Interrupt is enabled). When the USBSTS[SLI] (device controller suspend) is set, the device controller is suspended.

DCD response when the device controller is suspended is application specific and may involve switching to low power operation. Information on the bus power limits in suspend state can be found in USB 2.0 specification.

### 17.8.2.2.3 Resume

If the USB\_DR controller is suspended, its operation is resumed when any non-idle signaling is received on its upstream facing port.

In addition, the USB\_DR controller can signal the system to resume operation by forcing resume signaling to the upstream port. Resume signaling is sent upstream by writing a '1' to the PORTSC[FPR] (resume bit) while the device is in suspend state. Sending resume signal to an upstream port should cause the host to issue resume signaling and bring the suspended bus segment (one or more devices) back to the active condition.

#### NOTE

Before resume signaling can be used, the host must enable it by using the Set Feature command defined in device framework (Chapter 9) of the USB 2.0 Specification.

# 17.8.3 Managing endpoints

The USB 2.0 specification defines an endpoint, also called a device endpoint or an address endpoint as a uniquely addressable portion of a USB device that can source or sink data in a communications channel between the host and the device.

The endpoint address is specified by the combination of the endpoint number and the endpoint direction.

The channel between the host and an endpoint at a specific device represents a data pipe. Endpoint 0 for a device is always a control type data channel used for device discovery and enumeration. Other types of endpoints support by USB include bulk, interrupt, and

#### **Device operational model**

isochronous. Each endpoint type has specific behavior related to packet response and error handling. More detail on endpoint operation can be found in the USB 2.0 specification.

The USB\_DR controller supports up to six endpoint specified numbers. The DCD can enable, disable, and configure each endpoint.

Each endpoint direction is essentially independent and can be configured with differing behavior in each direction. For example, the DCD can configure endpoint 1-IN to be a bulk endpoint and endpoint 1-OUT to be an isochronous endpoint. This helps to conserve the total number of endpoints required for device operation. The only exception is that control endpoints must use both directions on a single endpoint number to function as a control endpoint. Endpoint 0, for example, is always a control endpoint and uses the pair of directions.

Each endpoint direction requires a queue head allocated in memory. If the maximum of 6 endpoint numbers, one for each endpoint direction are being used by the device controller, then 12 queue heads are required. The operation of an endpoint and use of queue heads are described later in this document.

# 17.8.3.1 Endpoint initialization

After hardware reset, all endpoints except endpoint zero are uninitialized and disabled.

The DCD must configure and enable each endpoint by writing to configuration bit in the ENDPTCTRL*n* register. Each 32-bit ENDPTCTRL*n* is split into an upper and lower half. The lower half of ENDPTCTRL*n* is used to configure the receive or OUT endpoint and the upper half is likewise used to configure the corresponding transmit or IN endpoint. Control endpoints must be configured the same in both the upper and lower half of the ENDPTCTRL*n* register otherwise the behavior is undefined. The table below shows how to construct a configuration word for endpoint initialization.

Table 17-97. Device controller endpoint initialization

Field Value

Data Toggle Reset

| Field               | Value          |
|---------------------|----------------|
| Data Toggle Reset   | 1              |
| Data Toggle Inhibit | 0              |
| Endpoint Type       | 00 Control     |
|                     | 01 Isochronous |
|                     | 10 Bulk        |
|                     | 11 Interrupt   |
| Endpoint Stall      | 0              |

### 17.8.3.1.1 Stalling

There are two occasions where the USB\_DR controller may need to return to the host a STALL.

The first occasion is the functional stall, which is a condition set by the DCD as described in the USB 2.0 device framework (Chapter 9). A functional stall is only used on non-control endpoints and can be enabled in the device controller by setting the endpoint stall bit in the ENDPTCTRL*n* register associated with the given endpoint and the given direction. In a functional stall condition, the device controller will continue to return STALL responses to all transactions occurring on the respective endpoint and direction until the endpoint stall bit is cleared by the DCD.

A protocol stall, unlike a function stall, is used on control endpoints is automatically cleared by the device controller at the start of a new control transaction (setup phase). When enabling a protocol stall, the DCD should enable the stall bits (both directions) as a pair. A single write to the ENDPTCTRL*n* register can ensure that both stall bits are set at the same instant.

### NOTE

Any write to the ENDPTCTRL*n* register during operational mode must preserve the endpoint type field (that is, perform a read-modify-write).

The table below describes the device controller stall response matrix.

| USB Packet                                            | Endpoint<br>Stall Bit. | Effect on STALL Bit. | USB Response |
|-------------------------------------------------------|------------------------|----------------------|--------------|
| SETUP packet received by a non-control endpoint       | N/A                    | None                 | STALL        |
| IN/OUT/PING packet received by a non-control endpoint | '1                     | None                 | STALL        |
| IN/OUT/PING packet received by a non-control endpoint | '0                     | None                 | ACK/NAK/NYET |
| SETUP packet received by a control endpoint           | N/A                    | Cleared              | ACK          |
| IN/OUT/PING packet received by a control endpoint     | '1                     | None                 | STALL        |
| IN/OUT/PING packet received by a control endpoint     | '0                     | None                 | ACK/NAK/NYET |

Table 17-98. Device controller stall response matrix

# 17.8.3.2 Data toggle

Data toggle is a mechanism to maintain data coherency between host and device for any given data pipe.

#### **Device operational model**

For more information on data toggle, refer to the *Universal Serial Bus Revision 2.0 Specification*.

### 17.8.3.2.1 Data toggle reset

The DCD may reset the data toggle state bit and cause the data toggle sequence to reset in the device controller by writing a '1' to the data toggle reset bit in the ENDPTCTRL*n* register.

This should only be necessary when configuring/initializing an endpoint or returning from a STALL condition.

### 17.8.3.2.2 Data toggle inhibit

This feature is for test purposes only and should never be used during normal device controller operation.

Setting the data toggle Inhibit bit active ('1') causes the USB\_DR controller to ignore the data toggle pattern that is normally sent and accept all incoming data packets regardless of the data toggle state.

In normal operation, the USB\_DR controller checks the DATA0/DATA1 bit against the data toggle state bit to determine if the packet is valid. If Data PID does not match the data toggle state bit maintained by the device controller for that endpoint, the Data toggle is considered not valid. If the data toggle is not valid, the device controller assumes the packet was already received and discards the packet (not reporting it to the DCD). To prevent the USB\_DR controller from re-sending the same packet, the device controller will respond to the error packet by acknowledging it with either an ACK or NYET response.

# 17.8.3.3 Device operational model for packet transfers

All transactions on the USB bus are initiated by the host and in turn, the device must respond to any request from the host within the turnaround time stated in the *Universal Serial Bus Revision 2.0 Specification*.

A USB host will send requests to the USB\_DR controller in an order that can not be precisely predicted as a single pipeline, so it is not possible to prepare a single packet for the device controller to execute. However, the order of packet requests is predictable when the endpoint number and direction is considered. For example, if endpoint 2 (transmit direction) is configured as a bulk pipe, then the host sends IN requests to that endpoint. This USB\_DR controller prepares packets for each endpoint/direction in anticipation of the host request. The process of preparing the device controller to send or

receive data in response to host initiated transaction on the bus is referred to as 'priming' the endpoint. This term is used throughout the following documentation to describe the USB\_DR controller operation so the DCD can be architected properly use priming. Further, note that the term 'flushing' is used to describe the action of clearing a packet that was queued for execution.

### 17.8.3.3.1 Priming transmit endpoints

Priming a transmit endpoint will cause the device controller to fetch the device transfer descriptor (dTD) for the transaction pointed to by the device queue head (dQH).

After the dTD is fetched, it is stored in the dQH until the device controller completes the transfer described by the dTD. Storing the dTD in the dQH allows the device controller to fetch the operating context needed to handle a request from the host without the need to follow the linked list, starting at the dQH when the host request is received.

After the device has loaded the dTD, the leading data in the packet is stored in a FIFO in the device controller. This FIFO is split into virtual channels so that the leading data can be stored for any endpoint.

After a priming request is complete, an endpoint state of primed is indicated in the ENDPTSTATUS register. For a primed transmit endpoint, the device controller can respond to an IN request from the host and meet the stringent bus turnaround time of High Speed USB.

Since only the leading data is stored in the device controller FIFO, it is necessary for the device controller to begin filling in behind leading data after the transaction starts. The FIFO has been sized to account for the maximum latency that can be incurred by the system memory bus.

# 17.8.3.3.2 Priming receive endpoints

Priming receive endpoints is identical to priming of transmit endpoints from the point of view of the DCD.

At the device controller the major difference in the operational model is that there is no data movement of the leading packet data simply because the data is to be received from the host.

Note as part of the architecture, the FIFO for the receive endpoints is not partitioned into multiple channels like the transmit FIFO. Thus, the size of the RX FIFO does not scale with the number of endpoints.

# 17.8.3.4 Interrupt/bulk endpoint operational model

The behaviors of the device controller for interrupt and bulk endpoints are identical.

All valid IN and OUT transactions to bulk pipes will handshake with a NAK unless the endpoint had been primed. Once the endpoint has been primed, data delivery will commence.

A dTD is retired by the device controller when the packets described in the transfer descriptor have been completed. Each dTD describes N packets to be transferred according to the USB Variable Length transfer protocol. The formula and the following tables describe how the device controller computes the number and length of the packets to be sent/received by the USB vary according to the total number of bytes and maximum packet length.

With Zero Length Termination (ZLT) = 0

N = INT(number of bytes/max. packet length) + 1

With Zero Length Termination (ZLT) = 1

N = MAXINT(number of bytes/max. packet length)

Table 17-99. Variable length transfer protocol example (ZLT = 0)

| Bytes (dTD) | Max. packet length (dQH) | N | P1  | P2  | Р3 |
|-------------|--------------------------|---|-----|-----|----|
| 511         | 256                      | 2 | 256 | 255 | -  |
| 512         | 256                      | 3 | 256 | 256 | 0  |
| 512         | 512                      | 2 | 512 | 0   | -  |

Table 17-100. Variable length transfer protocol example (ZLT = 1)

| Bytes (dTD) | Max. packet length (dQH) | N | P1  | P2  | Р3 |
|-------------|--------------------------|---|-----|-----|----|
| 511         | 256                      | 2 | 256 | 255 | -  |
| 512         | 256                      | 2 | 256 | 256 | -  |
| 512         | 512                      | 1 | 512 | -   | -  |

#### NOTE

The MULT field in the dQH must be set to '00' for bulk, interrupt, and control endpoints.

# TX-dTD is complete when:

• All packets described dTD were successfully transmitted. \*\*\* Total bytes in dTD will equal zero when this occurs.

### RX-dTD is complete when:

- All packets described in dTD were successfully received. \*\*\* Total bytes in dTD will equal zero when this occurs.
- A short packet (number of bytes < maximum packet length) was received. \*\*\* This is a successful transfer completion; DCD must check Total Bytes in dTD to determine the number of bytes that are remaining. From the total bytes remaining in the dTD, the DCD can compute the actual bytes received.
- A long packet was received (number of bytes > maximum packet size) OR (total bytes received > total bytes specified). \*\*\* This is an error condition. The device controller will discard the remaining packet, and set the Buffer Error bit in the dTD. In addition, the endpoint is flushed and the USBERR interrupt will become active.

On the successful completion of the packet(s) described by the dTD, the active bit in the dTD is cleared and the next pointer will be followed when the Terminate bit is clear. When the Terminate bit is set, the USB\_DR controller will flush the endpoint/direction and cease operations for that endpoint/direction.

On the unsuccessful completion of a packet (see long packet above), the dQH is left pointing to the dTD that was in error. In order to recover from this error condition, the DCD must properly re-initialize the dQH by clearing the active bit and update the nextTD pointer before attempting to re-prime the endpoint.

### **NOTE**

All packet level errors such as a missing handshake or CRC error will be retried automatically by the device controller.

There is no required interaction with the DCD for handling such errors.

# 17.8.3.4.1 Interrupt/bulk endpoint bus response matrix

The table below shows the interrupt/bulk endpoint bus response matrix.

|         | Stall  | Not Primed | Primed                          | Underflow             | Overflow |
|---------|--------|------------|---------------------------------|-----------------------|----------|
| Setup   | Ignore | Ignore     | Ignore                          | N/A                   | N/A      |
| In      | STALL  | NAK        | Transmit                        | BS Error <sup>1</sup> | N/A      |
| Out     | STALL  | NAK        | Receive + NYET/ACK <sup>2</sup> | N/A                   | NAK      |
| Ping    | STALL  | NAK        | ACK                             | N/A                   | N/A      |
| Invalid | Ignore | Ignore     | Ignore                          | Ignore                | Ignore   |

Table 17-101. Interrupt/bulk endpoint bus response matrix

SYSERR-System error should never occur when the latency FIFOs are correctly sized and the DCD is responsive.

<sup>1.</sup> Force Bit Stuff Error.

<sup>2.</sup> NYET/ACK-NYET unless the Transfer Descriptor has packets remaining according to the USB variable length protocol then ACK.

# 17.8.3.5 Control endpoint operation model

This section discusses the control endpoint operation model.

# 17.8.3.5.1 Setup phase

All requests to a control endpoint begin with a setup phase followed by an optional data phase and a required status phase.

The USB\_DR controller will always accept the setup phase unless the setup lockout is engaged.

The setup lockout will engage so that future setup packets are ignored. Lockout of setup packets ensures that while software is reading the setup packet stored in the queue head, that data is not written as it is being read potentially causing an invalid setup packet.

The setup lockout mechanism can be disabled and a tripwire type semaphore will ensure that the setup packet payload is extracted from the queue head without being corrupted by an incoming setup packet. This is the preferred behavior because ignoring repeated setup packets due to long software interrupt latency would be a compliance issue.

### Setup Packet Handling

• Disable Setup Lockout by writing '1' to Setup Lockout Mode (SLOM) in USBMODE (once at initialization). Setup lockout is not necessary when using the tripwire as described below.

### NOTE

Leaving the Setup Lockout Mode as '0' will result in a potential compliance issue.

- After receiving an interrupt and inspecting ENDPTSETUPSTAT to determine that a setup packet was received on a particular pipe:
  - Write '1' to clear corresponding bit ENDPTSETUPSTAT.
  - Write '1' to Setup Tripwire (SUTW) in USBCMD register.
  - Duplicate contents of dQH.SetupBuffer into local software byte array.
  - Read Setup TripWire (SUTW) in USBCMD register. (if set-continue; if cleared-goto 2)
  - Write '0' to clear Setup Tripwire (SUTW) in USBCMD register.
  - Process setup packet using local software byte array copy and execute status/ handshake phases.

### NOTE

After receiving a new setup packet the status and/or handshake phases may still be pending from a previous control sequence. These should be flushed and de-allocated before linking a new status and/or handshake dTD for the most recent setup packet.

### 17.8.3.5.2 Data phase

If the control transfer requires a data stage following the setup phase, the DCD must create a device transfer descriptor for the data phase and prime the transfer.

After priming the packet, the DCD must verify a new setup packet has not been received by reading the ENDPTSETUPSTAT register immediately verifying that the prime had completed. A prime will complete when the associated bit in the ENDPTPRIME register is zero and the associated bit in the ENDPTSTATUS register is a one. If a prime fails, that is, The ENDPTPRIME bit goes to zero and the ENDPTSTATUS bit is not set, then the prime has failed. This can only be due to improper setup of the dQH, dTD or a setup arriving during the prime operation. If a new setup packet is indicated after the ENDPTPRIME bit is cleared, then the transfer descriptor can be freed and the DCD must reinterpret the setup packet.

Should a setup arrive after the data stage is primed, the device controller will automatically clear the prime status (ENDPTSTATUS) to enforce data coherency with the setup packet.

### NOTE

The MULT field in the dQH must be set to '00' for bulk, interrupt, and control endpoints.

#### NOTE

Error handling of data phase packets is the same as bulk packets described previously.

# 17.8.3.5.3 Status phase

Similar to the data phase, the DCD must create a transfer descriptor (with byte length equal zero) and prime the endpoint for the status phase.

The DCD must also perform the same checks of the ENDPTSETUPSTAT as described above in the data phase.

#### NOTE

The MULT field in the dQH must be set to '00' for bulk, interrupt, and control endpoints.

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

### NOTE

Error handling of data phase packets is the same as bulk packets described previously.

### 17.8.3.5.4 Control endpoint bus response matrix

The table below shows the device controller response to packets on a control endpoint, according to the device controller state.

| Token type |        | Setup lockout |                                     |                       |                     |        |
|------------|--------|---------------|-------------------------------------|-----------------------|---------------------|--------|
|            | Stall  | Not primed    | Primed                              | Underflow             | Overflow            |        |
| Setup      | ACK    | ACK           | ACK                                 | N/A                   | SYSERR <sup>1</sup> |        |
| In         | STALL  | NAK           | Transmit                            | BS Error <sup>2</sup> | N/A                 | N/A    |
| Out        | STALL  | NAK           | Receive + NYET/<br>ACK <sup>3</sup> | N/A                   | NAK                 | N/A    |
| Ping       | STALL  | NAK           | ACK                                 | N/A                   | N/A                 | N/A    |
| Invalid    | Ignore | Ignore        | Ignore                              | Ignore                | Ignore              | Ignore |

Table 17-102. Control endpoint bus response matrix

# 17.8.3.6 Isochronous endpoint operational model

Isochronous endpoints are used for real-time scheduled delivery of data and their operational model is significantly different than the host throttled Bulk, Interrupt, and Control data pipes.

Real time delivery by the USB\_DR controller is accomplished by the following:

- Exactly MULT Packets per (micro)Frame are transmitted/received. Note that MULT is a two-bit field in the device Queue Head. The variable length packet protocol is not used on isochronous endpoints.
- NAK responses are not used. Instead, zero length packets and sent in response to an IN request to an unprimed endpoints. For unprimed RX endpoints, the response to an OUT transaction is to ignore the packet within the device controller.
- Prime requests always schedule the transfer described in the dTD for the next (micro)frame. If the ISO-dTD is still active after that frame, then the ISO-dTD is held ready until executed or canceled by the DCD.

<sup>1.</sup> SYSERR-System error should never occur when the latency FIFOs are correctly sized and the DCD is responsive.

<sup>2.</sup> Force Bit Stuff Error.

<sup>3.</sup> NYET/ACK-NYET unless the Transfer Descriptor has packets remaining according to the USB variable length protocol then ACK.

The USB\_DR controller in host mode uses the periodic frame list to schedule data exchanges to Isochronous endpoints. The operational model for device mode does not use such a data structure. Instead, the same dTD used for Control/Bulk/Interrupt endpoints is also used for isochronous endpoints. The difference is in the handling of the dTD.

The first difference between bulk and ISO-endpoints is that priming an ISO-endpoint is a delayed operation such that an endpoint will become primed only after a SOF is received. After the DCD writes the prime bit, the prime bit is cleared as usual to indicate to software that the device controller completed a priming the dTD for transfer. Internal to the design, the device controller hardware masks that prime start until the next frame boundary. This behavior is hidden from the DCD but occurs so that the device controller can match the dTD to a specific (micro)frame.

Another difference with isochronous endpoints is that the transaction must wholly complete in a (micro)frame. Once an ISO transaction is started in a (micro)frame it will retire the corresponding dTD when MULT transactions occur or the device controller finds a fulfillment condition.

The transaction error bit set in the status field indicates a fulfillment error condition. When a fulfillment error occurs, the frame after the transfer failed to complete wholly, the device controller will force retire the ISO-dTD and move to the next ISO-dTD.

It is important to note that fulfillment errors are only caused due to partially completed packets. If no activity occurs to a primed ISO-dTD, the transaction will stay primed indefinitely. This means it is up to software discard transmit ISO-dTDs that pile up from a failure of the host to move the data.

Note that when the USB controller is in device mode and the host sends two consecutive ISO OUT transactions (for example: OUT - DATA0 - OUT - DATA1) with a short interpacket delay between DATA0 and the second OUT (less than 200 ns), the device sees the DATA1 packet as a short-packet even if it is correctly formed. In this case, the device terminates the transfer, generating an IOC interrupt (USBSTS[UI]). Note however, that DATA0 is correctly received.

Finally, the last difference with ISO packets is in the data level error handling. When a CRC error occurs on a received packet, the packet is not retried similar to bulk and control endpoints. Instead, the CRC is noted by setting the Transaction Error bit and the data is stored as usual for the application software to sort out.

- TX Packet Retired
  - MULT counter reaches zero.
  - Fulfillment Error [Transaction Error bit is set]
  - #Packets Occurred > 0 AND # Packets Occurred < MULT

### NOTE

For TX-ISO, MULT Counter can be loaded with a lesser value in the dTD Multiplier Override field. If the Multiplier Override is zero, the MULT Counter is initialized to the Multiplier in the QH.

- RX Packet Retired:
  - MULT counter reaches zero.
  - Non-MDATA Data PID is received
  - Overflow Error:
  - Packet received is > maximum packet length. [Buffer Error bit is set]
  - Packet received exceeds total bytes allocated in dTD. [Buffer Error bit is set]
  - Fulfillment Error [Transaction Error bit is set]
  - # Packets Occurred > 0 AND # Packets Occurred < MULT
  - CRC Error [Transaction Error bit is set]

### NOTE

For ISO, when a dTD is retired, the next dTD is primed for the next frame. For continuous (micro)frame to (micro)frame operation the DCD should ensure that the dTD linked-list is out ahead of the device controller by at least two (micro)frames.

# 17.8.3.6.1 Isochronous pipe synchronization

When it is necessary to synchronize an isochronous data pipe to the host, the (micro)frame number (FRINDEX register) can be used as a marker.

To cause a packet transfer to occur at a specific (micro)frame number [N], the DCD should interrupt on SOF during frame N - 1. When the FRINDEX = N - 1, the DCD must write the prime bit. The USB\_DR controller will prime the isochronous endpoint in (micro)frame N - 1 so that the device controller will execute delivery during (micro)frame N.

### NOTE

Priming an endpoint towards the end of (micro)frame N - 1 will not guarantee delivery in (micro)frame N. The delivery may actually occur in (micro)frame N + 1 if device controller does not have enough time to complete the prime before the SOF for packet N is received.

Drop Packet

Ignore

Ignore

## 17.8.3.6.2 Isochronous endpoint bus response matrix

Ignore

Ignore

Ignore

The table below shows the isochronous endpoint bus response matrix.

|      | Stall                    | Not Primed  | Primed   | Underflow             | Overflow |
|------|--------------------------|-------------|----------|-----------------------|----------|
| etup | STALL                    | STALL       | STALL    | N/A                   | N/A      |
|      | NULL <sup>1</sup> Packet | NULL Packet | Transmit | BS Error <sup>2</sup> | N/A      |

Receive

Ignore

Ignore

N/A

Ignore

Ignore

Table 17-103. Isochronous endpoint bus response matrix

1. Zero Length Packet.

Setu In Out

Ping

Invalid

2. Force Bit Stuff Error.

# 17.8.4 Managing queue heads

Ignore

Ignore

Ignore

The figure below shows the endpoint queue head diagram.



Figure 17-63. Endpoint queue head diagram

The device queue head (dQH) points to the linked list of transfer tasks, each depicted by the device Transfer Descriptor (dTD). An area of memory pointed to by ENDPOINTLISTADDR contains a group of all dQHs in a sequential list as shown in Figure 17-63. The even elements in the list of dQH's are used for receive endpoints (OUT/SETUP) and the odd elements are used for transmit endpoints (IN/INTERRUPT). Device transfer descriptors are linked head to tail starting at the queue head and ending at a terminate bit. Once the dTD has been retired, it will no longer be part of the linked list

#### **Device operational model**

from the queue head. Therefore, software is required to track all transfer descriptors since pointers will no longer exist within the queue head once the dTD is retired (see Software link pointers).

In addition to the current and next pointers and the dTD overlay, the dQH also contains the following parameters for the associated endpoint: Multipler, Maximum Packet Length, Interrupt On Setup. The complete initialization of the dQH including these fields is demonstrated in the next section.

### 17.8.4.1 Queue head initialization

One pair of device queue heads must be initialized for each active endpoint.

To initialize a device queue head:

- Write the MaxPacketSize field as required by the USB Chapter 9 or application specific protocol.
- Write the multiplier field to 0 for control, bulk, and interrupt endpoints. For ISO endpoints, set the multiplier to 1, 2, or 3 as required bandwidth an in conjunction with the USB Chapter 9 protocol. Note that in FS mode, the multiplier field can only be 1 for ISO endpoints.
- Write the next dTD Terminate bit field to '1.'
- Write the Active bit in the status field to '0.'
- Write the Halt bit in the status field to '0.'

#### NOTE

The DCD must only modify dQH if the associated endpoint is not primed and there are no outstanding dTDs.

# 17.8.4.2 Operational model for setup transfers

As discussed in Control endpoint operation model, setup transfer requires special treatment by the DCD.

A setup transfer does not use a dTD but instead stores the incoming data from a setup packet in an 8-byte buffer within the dQH.

Upon receiving notification of the setup packet, the DCD should handle the setup transfer as demonstrated here:

- 1. Copy setup buffer contents from dQH RX to software buffer.
- 2. Acknowledge setup backup by writing a '1' to the corresponding bit in ENDPTSETUPSTAT.

#### NOTE

The acknowledge must occur before continuing to process the setup packet.

#### NOTE

After the acknowledge has occurred, the DCD must not attempt to access the setup buffer in the dQH - RX. Only the local software copy should be examined.

3. Check for pending data or status dTD's from previous control transfers and flush if any exist as discussed in Flushing/depriming an endpoint.

#### NOTE

It is possible for the device controller to receive setup packets before previous control transfers complete. Existing control packets in progress must be flushed and the new control packet completed.

4. Decode setup packet and prepare data phase [optional] and status phase transfer as required by the USB Chapter 9 or application specific protocol.

# 17.8.5 Managing transfers with transfer descriptors

This section describes software link pointers, transfer descriptors, transfer completion and the device error matrix.

### 17.8.5.1 Software link pointers

It is necessary for the DCD software to maintain head and tail pointers for the linked list of dTDs for each respective queue head.

This is necessary because the dQH only maintains pointers to the current working dTD and the next dTD to be executed. The operations described in next section for managing dTD will assume the DCD can use reference the head and tail of the dTD linked list.

#### NOTE

To conserve memory, the reserved fields at the end of the dQH can be used to store the Head and Tail pointers but it still remains the responsibility of the DCD to maintain the pointers.

The figure below shows the software link pointers.



Figure 17-64. Software link pointers

# 17.8.5.2 Building a transfer descriptor

Before a transfer can be executed from the linked list, a dTD must be built to describe the transfer.

Use the following procedure for building dTDs.

Allocate 8-DWord dTD block of memory aligned to 8-DWord boundaries. Example: bit address 4-0 would be equal to '00000'.

Write the following fields:

- 1. Initialize first seven DWords to '0'.
- 2. Set the terminate bit to '1'.
- 3. Fill in total bytes with transfer size.
- 4. Set the interrupt on complete if desired.
- 5. Initialize the status field with the active bit set to '1' and all remaining status bits set to '0'.
- 6. Fill in buffer pointer page 0 and the current offset to point to the start of the data buffer.
- 7. Initialize buffer pointer page 1 through page 4 to be one greater than each of the previous buffer pointer.

### 17.8.5.3 Executing a transfer descriptor

To safely add a dTD, the DCD must account for the event in which the device controller reaches the end of the dTD list at the same time a new dTD is being added to the end of the list.

First, determine whether the link list is empty by checking the DCD driver to see if the pipe is empty (internal representation of linked-list should indicate if any packets are outstanding). Then follow the sequence of actions in the following list as appropriate, depending on whether the link list is empty or not empty.

### Case 1: Link list is empty

- 1. Write dQH next pointer AND dQH terminate bit to '0' as a single DWord operation.
- 2. Clear active and halt bit in dQH (in case set from a previous error).
- 3. Prime endpoint by writing '1' to correct bit position in ENDPTPRIME.

### Case 2: Link list is not empty

- 1. Add dTD to end of linked list.
- 2. Read correct prime bit in ENDPTPRIME-if '1' DONE.
- 3. Set ATDTW bit in USBCMD register to '1'.
- 4. Read correct status bit in ENDPTSTATUS. (store in tmp. variable for later).
- 5. Read ATDTW bit in USBCMD register.

If '0' goto 3.

If '1' continue to 6.

- 6. Write ATDTW bit in USBCMD register to '0'.
- 7. If status bit read in (4) is '1' DONE.
- 8. If status bit read in (4) is '0' then Goto Case 1: Step 1.

# 17.8.5.4 Transfer completion

After a dTD has been initialized and the associated endpoint primed, the device controller will execute the transfer upon the host-initiated request.

The DCD is notified with a USB interrupt if the Interrupt On Complete bit was set or alternately, the DCD can poll the endpoint complete register to find when the dTD had been executed. After a dTD has been executed, DCD can check the status bits to determine success or failure.

#### NOTE

Multiple dTD can be completed in a single endpoint complete notification. After clearing the notification, DCD must search the dTD linked list and retire all dTDs that have finished (Active bit cleared).

#### **Device operational model**

By reading the status fields of the completed dTDs, the DCD can determine if the transfers completed successfully. Success is determined with the following combination of status bits:

- Active = 0
- Halted = 0
- Transaction Error = 0
- Data Buffer Error = 0

Should any combination other than the one shown above exist, the DCD must take proper action. Transfer failure mechanisms are indicated in the Device Error Matrix.

In addition to checking the status bit the DCD must read the Transfer Bytes field to determine the actual bytes transferred. When a transfer is complete, the Total Bytes transferred is by decremented by the actual bytes transferred. For Transmit packets, a packet is only complete after the actual bytes reaches zero, but for receive packets, the host may send fewer bytes in the transfer according the USB variable length packet protocol.

# 17.8.5.5 Flushing/depriming an endpoint

It is necessary for the DCD to flush to deprime one or more endpoints on a USB device reset or during a broken control transfer.

There may also be application specific requirements to stop transfers in progress. The following procedure can be used by the DCD to stop a transfer in progress:

- 1. Write a '1' to the corresponding bit(s) in ENDPTFLUSH.
- 2. Wait until all bits in ENDPTFLUSH are '0'.
- 3. Software note: this operation may take a large amount of time depending on the USB bus activity. It is not desirable to have this wait loop within an interrupt service routine.
- 4. Read ENDPTSTATUS to ensure that for all endpoints commanded to be flushed, that the corresponding bits are now '0" If the corresponding bits are '1' after step #2 has finished, then the flush failed as described in the following:

Explanation: In very rare cases, a packet is in progress to the particular endpoint when commanded flush using ENDPTFLUSH. A safeguard is in place to refuse the flush to ensure that the packet in progress completes successfully. The DCD may need to repeatedly flush any endpoints that fail to flush be repeating steps 1-3 until each endpoint is successfully flushed.

#### 17.8.5.6 Device error matrix

The table below summarizes packet errors that are not automatically handled by the USB controller.

Table 17-104. Device error matrix

| Error                 | Direction | Packet Type | Data Buffer<br>Error Bit | Transaction<br>Error Bit |
|-----------------------|-----------|-------------|--------------------------|--------------------------|
| Overflow **           | RX        | Any         | 1                        | 0                        |
| ISO Packet Error      | RX        | ISO         | 0                        | 1                        |
| ISO Fulfillment Error | Both      | ISO         | 0                        | 1                        |

Notice that the device controller handles all errors on Bulk/Control/Interrupt Endpoints except for a data buffer overflow. However, for ISO endpoints, errors packets are not retried and errors are tagged as indicated. The table below provides the error descriptions.

Table 17-105. Error descriptions

| Overflow                 | Number of bytes received exceeded max. packet size or total buffer length.                                                                                                                                                                                                                                                                                                                                              |  |  |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                          | <b>NOTE:</b> This error also sets the Halt bit in the dQH. If there are dTDs remaining in the linked list for the endpoint, they will not be executed.                                                                                                                                                                                                                                                                  |  |  |
| ISO Packet<br>Error      | CRC Error on received ISO packet. Contents not guaranteed to be correct.                                                                                                                                                                                                                                                                                                                                                |  |  |
| ISO Fulfillment<br>Error | Host failed to complete the number of packets defined in the dQH mult field within the given (micro)frame. For scheduled data delivery the DCD may need to readjust the data queue because a fulfillment error will cause Device Controller to cease data transfers on the pipe for one (micro)frame. During the dead (micro)frame, the Device Controller reports error on the pipe and primes for the following frame. |  |  |

# 17.8.6 Servicing interrupts

The interrupt service routine must consider that there are high-frequency, low-frequency operations, and error operations and order accordingly.

# 17.8.6.1 High-frequency interrupts

High frequency interrupts in particular should be handed in the order shown in the table below. The most important of these is listed first because the DCD must acknowledge a setup buffer in the timeliest manner possible.

Table 17-106. Interrupt handling order

| Execution order | Interrupt                                      | Action                                                                                                                                                                                   |
|-----------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1a              | USB Interrupt <sup>1</sup><br>ENDPTSETUPSTATUS | Copy contents of setup buffer and acknowledge setup packet (as indicated in Managing queue heads). Process setup packet according to USB 2.0 Chapter 9 or application specific protocol. |
| 1b              | USB Interrupt<br>ENDPTCOMPLETE                 | Handle completion of dTD as indicated in Managing queue heads.                                                                                                                           |
| 2               | SOF Interrupt                                  | Action as deemed necessary by application. This interrupt may not have a use in all applications.                                                                                        |

It is likely that multiple interrupts to stack up on any call to the Interrupt Service Routine AND during the Interrupt Service
Routine.

# 17.8.6.2 Low-frequency interrupts

The low frequency events include the interrupts shown in the table below.

These interrupts can be handled in any order because they do not occur often in comparison to the high-frequency interrupts.

Table 17-107. Low frequency interrupt events

| Interrupt              | Action                                                              |
|------------------------|---------------------------------------------------------------------|
| Port Change            | Change software state information.                                  |
| Sleep enable (Suspend) | Change software state information. Low power handling as necessary. |
| Reset Received         | Change software state information. Abort pending transfers.         |

# 17.8.6.3 Error interrupts

Error interrupts are the least frequently occurring events. They should be placed last in the interrupt service routine.

The table below shows the error interrupt events.

Table 17-108. Error interrupt events

| Interrupt           | Action                                                                                                                                                                                                                      |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USB Error Interrupt | This error is redundant because it combines USB Interrupt and an error status in the dTD. The DCD will more aptly handle packet-level errors by checking dTD status field upon receipt of USB Interrupt (w/ ENDPTCOMPLETE). |
| System Error        | Unrecoverable error. Immediate Reset of core; free transfers buffers in progress and restart the DCD.                                                                                                                       |

# 17.9 Deviations from the EHCI specifications

The host mode operation of the USB DR module is nearly EHCI-compatible with few minor differences. For the most part, the module conforms to the data structures and operations described in Section 3, "Data Structures," and Section 4, "Operational Model," in the EHCI specification. The particulars of the deviations occur in the following areas:

- Embedded transaction translator-Allows direct attachment of FS and LS devices in host mode without the need for a companion controller.
- Device operation-In host mode, the device operational registers are generally disabled and thus device mode is mostly transparent when in host mode. However, there are a couple exceptions documented in the following sections.
- Embedded design interface-The module does not have a PCI interface and therefore the PCI configuration registers described in the EHCI specification are not applicable.

# 17.9.1 Embedded transaction translator function

The DR module supports directly connected full and low speed devices without requiring a companion controller by including the capabilities of a USB 2.0 high speed hub transaction translator.

Although there is no separate transaction translator block in the system, the transaction translator function normally associated with a high speed hub has been implemented within the DMA and Protocol engine blocks. The embedded transaction translator function is an extension to EHCI interface, but makes use of the standard data structures and operational models that exist in the EHCI specification to support full and low speed devices.

### 17.9.1.1 Capability registers

The following additions have been added to the capability registers to support the embedded transaction translator function:

- N TT added to HSCPARAMS-Host Controller Structural Parameters
- N\_PTT added to HSCPARAMS-Host Controller Structural Parameters

See Host controller structural parameters (USB\_HCSPARAMS), for usage information.

# 17.9.1.2 Operational registers

The following additions have been added to the operational registers to support the embedded TT:

- ASYNCTTSTS is a new register.
- Addition of two-bit Port Speed (PSPD) to the PORTSC register.

# **17.9.1.3 Discovery**

In a standard EHCI controller design, the EHCI host controller driver detects a full speed (FS) or low speed (LS) device by noting if the port enable bit is set after the port reset operation.

The port enable will only be set in a standard EHCI controller implementation after the port reset operation and when the host and device negotiate a High-Speed connection (that is, Chirp completes successfully).

The module always sets the port enable after the port reset operation regardless of the result of the host device chirp result. The resulting port speed is indicated by the PSPD field in PORTSC. Therefore, the standard EHCI host controller driver requires an alteration to handle directly connected full- and low-speed devices or hubs. The table below summarizes the functional differences between EHCI and EHCI with embedded TT.

Table 17-109. Functional differences between EHCl and EHCl with embedded TT

| Standard EHCI | EHCI with embedded transaction translator                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------|
|               | After port enable bit is set following a connection and reset sequence, the device/hub speed is noted from PORTSC. |

Table continues on the next page...

Table 17-109. Functional differences between EHCl and EHCl with embedded TT (continued)

| Standard EHCI                                                                                                                                                                                                 | EHCI with embedded transaction translator                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FS and LS devices are assumed to be downstream from a HS hub thus, all port-level control is performed through the Hub Class to the nearest Hub.                                                              | FS and LS device can be either downstream from a HS hub or directly attached. When the FS/LS device is downstream from a HS hub, then port-level control is done using the Hub Class through the nearest Hub. When a FS/LS device is directly attached, then port-level control is accomplished using PORTSC. |
| FS and LS devices are assumed to be downstream from a HS hub with HubAddr=X. [where HubAddr > 0 and HubAddr is the address of the Hub where the bus transitions from HS to FS/LS (that is, Split target hub)] | FS and LS device can be either downstream from a HS hub with HubAddr = X [HubAddr > 0] or directly attached [where HubAddr = 0 and HubAddr is the address of the Root Hub where the bus transitions from HS to FS/LS (that is, Split target hub is the root hub)]                                             |

#### 17.9.1.4 Data structures

The same data structures used for FS/LS transactions though a HS hub are also used for transactions through the root hub.

The following list demonstrates how the hub address and endpoint speed fields should be set for directly attached FS/LS devices and hubs:

- 1. QH (for direct attach FS/LS)-Async. (Bulk/Control Endpoints) Periodic (Interrupt)
  - Hub Address = 0
  - Transactions to direct attached device/hub.
    - QH.EPS = Port Speed
  - Transactions to a device downstream from direct attached FS hub.
    - QH.EPS = Downstream Device Speed

#### **NOTE**

When QH.EPS = 01 (LS) and PORTSC[PSPD] = 00 (FS), a LS-pre-pid is sent before the transmitting LS traffic.

Maximum Packet Size must be less than or equal 64 or undefined behavior may result.

- 2. siTD (for direct attach FS)-Periodic (ISO Endpoint)
  - All FS ISO transactions:
    - Hub Address = 0
    - siTD.EPS = 00 (full speed)

Maximum packet size must less than or equal to 1023 or undefined behavior may result.

### 17.9.1.5 Operational model

The operational models are well defined for the behavior of the transaction translator (see *Universal Serial Bus Revision 2.0 Specification*) and for the EHCI controller moving packets between system memory and a USB-HS hub.

Since the embedded transaction translator exists within the DR module there is no physical bus between EHCI host controller driver and the USB FS/LS bus. These sections will briefly discuss the operational model for how the EHCI and transaction translator operational models are combined without the physical bus between. The following sections assume the reader is familiar with both the EHCI and USB 2.0 transaction translator operational models.

### 17.9.1.5.1 Microframe pipeline

The EHCI operational model uses the concept of H-frames and B-frames to describe the pipeline between the host (H) and the bus (B).

The embedded transaction translator shall use the same pipeline algorithms specified in the *Universal Serial Bus Revision 2.0 Specification* for a Hub-based transaction translator.

All periodic transfers always begin at B-frame 0 (after SOF) and continue until the stored periodic transfers are complete. As an example of the microframe pipeline implemented in the embedded transaction translator, all periodic transfers that are tagged in EHCI to execute in H-frame 0 will be ready to execute on the bus in B-frame 0.

It is important to note that when programming the S-mask and C-masks in the EHCI data structures to schedule periodic transfers for the embedded transaction translator, the EHCI host controller driver must follow the same rules specified in EHCI for programming the S-mask and C-mask for downstream Hub-based transaction translators.

Once periodic transfers are exhausted, any stored asynchronous transfer are moved. Asynchronous transfers are opportunistic in that they shall execute whenever possible and their operation is not tied to H-frame and B-frame boundaries with the exception that an asynchronous transfer can not babble through the SOF (start of B-frame 0).

### 17.9.1.5.2 Split state machines

The start and complete split operational model differs from EHCI slightly because there is no bus medium between the EHCI controller and the embedded transaction translator.

Where a start or complete-split operation would occur by requesting the split to the HS hub, the start/complete split operation is simple an internal operation to the embedded transaction translator. The table below summarizes the conditions where handshakes are emulated from internal state instead of actual handshakes to HS split bus traffic.

Table 17-110. Emulated handshakes

| Condition                                            | Emulate TT response                  |
|------------------------------------------------------|--------------------------------------|
| Start-Split: All asynchronous buffers full           | NAK                                  |
| Start-Split: All periodic buffers full               | ERR                                  |
| Start-Split: Success for start of Async. Transaction | ACK                                  |
| Start-Split: Start Periodic Transaction              | No handshake (Ok)                    |
| Complete-Split: Failed to find transaction in queue  | Bus Time Out                         |
| Complete-Split: Transaction in Queue is Busy         | NYET                                 |
| Complete-Split: Transaction in Queue is Complete     | [Actual handshake from FS/LS device] |

### 17.9.1.5.3 Asynchronous transaction scheduling and buffer management

The following *Universal Serial Bus Revision 2.0 Specification* items are implemented in the embedded transaction translator:

- USB 2.0-11.17.3
  - Sequencing is provided and a packet length estimator ensures no full-speed/low-speed packet babbles into SOF time.
- USB 2.0-11.17.4
  - Transaction tracking for 2 data pipes.
- USB 2.0-11.17.5
  - Clear\_TT\_Buffer capability provided

### 17.9.1.5.4 Periodic transaction scheduling and buffer management

The following *Universal Serial Bus Revision 2.0 Specification* items are implemented in the embedded transaction translator:

- USB 2.0-11.18.6.[1-2]
  - Abort of pending start-splits
    - EOF (and not started in microframes 6)
    - Idle for more than 4 microframes
  - Abort of pending complete-splits
    - EOF
    - Idle for more than 4 microframes

#### NOTE

There is no data schedule mechanism for these transactions other than the microframe pipeline. The embedded TT assumes the number of packets scheduled in a frame does not exceed the frame duration (1 msec) or else undefined behavior may result.

### 17.9.1.5.5 Multiple transaction translators

The maximum number of embedded transaction translators that is currently supported is one as indicated by the N\_TT field in the HCSPARAMS register.

See Host controller structural parameters (USB\_HCSPARAMS), for more information.

# 17.9.2 Device operation

The co-existence of a device operational controller within the DR module has little effect on EHCI compatibility for host operation except as noted in this section.

# 17.9.3 Non-zero fields the register file

Some of the reserved fields and reserved addresses in the capability registers and operational registers have use in device mode, the following must be adhered to:

- Write operations to all EHCI reserved fields (some of which are device fields in the DR module) in the operation registers should always be written to zero. This is an EHCI requirement of the device controller driver that must be adhered to.
- Read operations by the module must properly mask EHCI reserved fields (some of which are device fields in the DR module registers).

# 17.9.4 SOF interrupt

The SOF interrupt is a free running 125 µsec interrupt for host mode.

EHCI does not specify this interrupt, but it has been added for convenience and as a potential software time base. Note that the free running interrupt is shared with the device-mode start-of-frame interrupt. See USB status (USB\_USBSTS), and USB interrupt enable (USB\_USBINTR), for more information.

# 17.9.5 Embedded design

This is an Embedded USB Host Controller as defined by the EHCI specification and thus does not implement the PCI configuration registers.

### 17.9.5.1 Frame adjust register

Given that the optional PCI configuration registers are not included in this implementation, there is no corresponding bit level timing adjustments like those provided by the Frame Adjust register in the PCI configuration registers.

Starts of microframes are timed precisely to 125 µsec using the transceiver clock as a reference clock. That is, 60-MHz transceiver clock for 8-bit physical interfaces and full-speed serial interfaces or 30-MHz transceiver clock.

### 17.9.6 Miscellaneous variations from EHCI

The modules support multiple physical interfaces which can operate in different modes when the module is configured with the software programmable Physical Interface Modes.

The control bits for selecting the PHY operating mode have been added to the PORTSC register providing a capability that is not defined by the EHCI specification.

# 17.9.6.1 **Discovery**

This section discusses port reset and port speed detection.

#### 17.9.6.1.1 Port reset

The port connect methods specified by EHCI require setting the port reset bit in the register for a duration of 10 msec.

Due to the complexity required to support the attachment of devices that are not high speed there are counter already present in the design that can count the 10 msec reset pulse to alleviate the requirement of the software to measure this duration. Therefore, the basic connection is then summarized as the following:

- [Port Change Interrupt] Port connect change occurs to notify the host controller driver that a device has attached.
- Software shall write a '1' to the reset the device.

#### **Deviations from the EHCI specifications**

- Software shall write a '0' to the reset the device after 10 msec.
  - This step, which is necessary in a standard EHCI design, may be omitted with this implementation. Should the EHCI host controller driver attempt to write a '0' to the reset bit while a reset is in progress the write will simple be ignored and the reset will continue until completion.
- [Port Change Interrupt] Port enable change occurs to notify the host controller that the device in now operational and at this point the port speed has been determined.

### 17.9.6.1.2 Port speed detection

After the port change interrupt indicates that a port is enabled, the EHCI stack should determine the port speed.

Unlike the EHCI implementation which will re-assign the port owner for any device that does not connect at High-Speed, this host controller supports direct attach of non-HS devices. Therefore, the following differences are important regarding port speed detection:

- Port owner is read-only and always reads 0.
- A 2-bit port speed indicator has been added to PORTSC to provide the current operating speed of the port to the host controller driver.
  - A 1-bit high-speed indicator has been added to PORTSC to signify that the port is in HS vs. FS/LS

# **Chapter 18 Enhanced Serial Peripheral Interface**

The enhanced serial peripheral interface (eSPI) allows the device to exchange data with peripheral devices such as EEPROMs, real-time clocks, A/D converters, and ISDN devices.

### 18.1 Introduction

The enhanced serial peripheral interface (eSPI) allows the device to exchange data with peripheral devices such as EEPROMs, real-time clocks, A/D converters, and ISDN devices.

The eSPI is a full-duplex, synchronous, character-oriented channel that supports a simple interface (receive, transmit, clock and chip selects). The eSPI consists of transmitter and receiver sections, an independent baud-rate generator, and a control unit. The transmitter and receiver sections use the same clock, which is derived from the eSPI baud rate generator in master mode. During an eSPI transfer, data is sent and received simultaneously.

The eSPI receiver and transmitter each have a FIFO of 32 bytes, as shown below. When the eSPI is disabled in the eSPI mode register (SPMODE[EN] = 0), it consumes little power.

#### Introduction



Figure 18-1. eSPI block diagram

### **18.1.1 Features**

The major features of the eSPI are listed as follows:

- Interface contains SPI\_MOSI, SPI\_MISO, SPI\_CLK, and 4 chip selects
- Supports eSPI master
- Supports RapidS<sup>TM</sup> full clock cycle operation
- Full-duplex or half-duplex master operation
- Supports Winbond dual output read
- Command in transaction level-easier for accessing eSPI devices
- Works with a range from 4-bit to 16-bit data characters
- Supports back-to-back character transmission and reception
- Supports reverse data mode for 8/16 bits data characters
- Supports single-master environment
- Maximum clock rate possible is (platform clock rate/2)
- Independent programmable baud rate generator
- Programmable clock phase and polarity.
- Supports four different configurations per chip select
- Local loopback capability for testing
- 32 bytes FIFO-support for SPI receiver and transmitter

# 18.1.2 eSPI transmission and reception process

As the eSPI is a character-oriented communication unit, the core is responsible for packing and unpacking the receive and transmit frames.

A frame consists of all of the characters transmitted or received during a completed eSPI transmission session, from the first character written to the eSPI transmit FIFO access register (SPITF) register to the last character transmitted with the total number as indicated in the command written to the eSPI command register (ESPI\_SPCOM) register.

The core receives data by reading the eSPI receive FIFO access register (SPIRF) when the RNE ("not empty") bit in the eSPI event register (SPIE) is set.

The core transmits data by writing it into the SPITF register. After the core writes the final character to SPITF it waits for DON bit in the SPIE register to be set indicating frame was fully transmitted. It might then write a new command to SPCOM register.

The eSPI sets the TNF ("not full") bit in SPIE register whenever its transmit FIFO is not full.

The eSPI core handshake protocol can be implemented by using a polling or interrupt mechanism. When using a polling mechanism, the core reads the SPIE in a predefined frequency and acts according to the value of the SPIE bits. The polling frequency depends on the eSPI serial channel frequency. When using the interrupt mechanism, setting either the TNF (not full) or RNE (not empty) bits of the SPIE causes an interrupt to the core. The core then reads the SPIE and acts appropriately.

# 18.1.3 Modes of operation

The eSPI can be programmed to work in a single master environment. This section describes eSPI master operation in a single-master configuration.

In master mode, the eSPI sends a message to the slave peripheral, which sends back a simultaneous reply. A single master with multiple slaves uses up to four chip select signals to selectively enable slaves, as shown below.



Figure 18-2. Single-master/multi-slave configuration

To start exchanging data, the core writes the data to be sent into the SPITF register. The eSPI then generates programmable clock pulses on SPI\_CLK for each character. It shifts Tx data out on the "eSPI master-out slave-in" (SPI\_MOSI) and Rx data in on the eSPI "master-in slave-out" (SPI\_MISO) simultaneously. During the transmission process the core is responsible for supplying the data whenever the eSPI requests it to ensure smooth operation.

The maximum sustained data rate that the eSPI supports depends on the software latency. However, the eSPI can transfer a single character at very high rates— a maximum (up to system clock / 2) specified by the chip hardware specifications (where system clock is defined as platform clock divided by 2). Gaps might be inserted between multiple frames.

# 18.2 External signal descriptions

The eSPI interface consists of transmit, receive, clock and chip selects.

# 18.2.1 Overview

Table 18-1. Signal properties

| Name           | Function                                                                                    |
|----------------|---------------------------------------------------------------------------------------------|
| SPI_MISO       | Master input slave output                                                                   |
| SPI_MOSI       | Master output slave input or second master input slave output for Winbond dual output read. |
| SPI_CLK        | Output serial clock connected to the other SPI_CLK.                                         |
| SPI_CS_B [0:3] | eSPI slave select outputs                                                                   |

# 18.2.2 ESPI detailed signal descriptions

Table 18-2. ESPI detailed signal descriptions

| Signal     | I/O | Description                                                                                                    |                                                                                                                               |
|------------|-----|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SPI_MISO   | ı   | Master inpu                                                                                                    | t slave output                                                                                                                |
|            |     | State                                                                                                          | Asserted-The data that has been received from the eSPI is high                                                                |
|            |     | meaning                                                                                                        | Negated-The data that has been received from the eSPI is low                                                                  |
|            |     | Timing                                                                                                         | Assertion-According to the SPI_CLK assertion/negation/in the middle of phase (depends on the SPMODEx configuration register)  |
|            |     |                                                                                                                | Negation-According to the SPI_CLK assertion/negation/in the middle of phase (depends on the SPMODEx configuration register)   |
| SPI_MOSI   | I/O | Master outp                                                                                                    | ut slave input or second master input slave output for Winbond dual output read                                               |
|            |     | State                                                                                                          | Asserted-The data that has been transmitted from/to the eSPI is high                                                          |
|            |     | meaning                                                                                                        | Negated-The data that has been transmitted from/to the eSPI is low                                                            |
|            |     | Timing                                                                                                         | Assertion-According to the SPI_CLK assertion/negation/in the middle of phase (depends on the SPMODEx configuration register). |
|            |     |                                                                                                                | Negation-According to the SPI_CLK assertion/negation/in the middle of phase (depends on the SPMODEx configuration register).  |
| SPI_CLK    | 0   | Serial clock out  State Assertion/negation-According to SPMODEx[PM,DIV16] register rate configurations meaning |                                                                                                                               |
|            |     |                                                                                                                |                                                                                                                               |
|            |     | Timing                                                                                                         | Assertion/negation-During frame reception/transmission                                                                        |
| SPI_CS_B O |     | eSPI slave s                                                                                                   | select outputs                                                                                                                |
| [0:3]      |     | State<br>meaning                                                                                               | Asserted- Slave 0, 1, 2, 3 is selected and master controls transmission/reception                                             |
|            |     |                                                                                                                | Negated-idle state                                                                                                            |
|            |     | Timing                                                                                                         | Assertion-A predefined time before frame starts, during frame transmission/reception,                                         |
|            |     |                                                                                                                | a predefined time after frame ends                                                                                            |
|            |     |                                                                                                                | Negation-When master is idle or controls another slave                                                                        |

#### Enhanced serial peripheral interface (eSPI) memory map

The eSPI can be configured as a master in single master environment. The master eSPI generates the transfer clock SPI\_CLK using the eSPI baud rate generator (BRG). The eSPI BRG takes as its input the platform clock divided by two.

SPI\_CLK is a gated clock, active only during data transfers. Four combinations of SPI\_CLK phase and polarity can be configured with the clock invert SPMODEx[CIx] and clock phase SPMODEx[CPx] register bits.

The eSPI master-in slave-out SPI\_MISO signal acts as an input for master devices and as an output for slave devices. Conversely, the master-out slave-in SPI\_MOSI signal is an output for master devices and an input for slave devices. However, it also acts as a second input for master devices and as a second output for slave devices when using Winbond dual output read.

SPI\_CLK is the clock output signal that shifts received data in from SPI\_MISO and transmitted data out to SPI\_MOSI. eSPI masters must output a slave select signal to enable eSPI slave devices.

# 18.3 Enhanced serial peripheral interface (eSPI) memory map

The table below shows the memory mapped registers of the eSPI and their offsets. It lists the offset, name, and a cross-reference to the complete description of each register. Note that the full register address comprises CCSRBAR together with the SPI block base address and offset listed in the table below.

#### **ESPI** memory map

| Offset<br>address<br>(hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| 7000                       | eSPI mode register (ESPI_SPMODE)                | 32                 | R/W    | 0000_100Fh  | 18.3.1/1461      |
| 7004                       | eSPI event register (ESPI_SPIE)                 | 32                 | R/W    | 0020_0000h  | 18.3.2/1463      |
| 7008                       | eSPI mask register (ESPI_SPIM)                  | 32                 | R/W    | 0000_0000h  | 18.3.3/1465      |
| 700C                       | eSPI command register (ESPI_SPCOM)              | 32                 | W      | 0000_0000h  | 18.3.4/1467      |
| 7010                       | eSPI transmit FIFO access register (ESPI_SPITF) | 32                 | W      | 0000_0000h  | 18.3.5/1469      |
| 7014                       | eSPI receive FIFO access register (ESPI_SPIRF)  | 32                 | R      | 0000_0000h  | 18.3.6/1471      |
| 7020                       | eSPI CS0 mode register (ESPI_SPMODE0)           | 32                 | R/W    | 0010_0000h  | 18.3.7/1472      |
| 7024                       | eSPI CS1 mode register (ESPI_SPMODE1)           | 32                 | R/W    | 0010_0000h  | 18.3.8/1474      |
| 7028                       | eSPI CS2 mode register (ESPI_SPMODE2)           | 32                 | R/W    | 0010_0000h  | 18.3.9/1476      |
| 702C                       | eSPI CS3 mode register (ESPI_SPMODE3)           | 32                 | R/W    | 0010_0000h  | 18.3.10/<br>1478 |

# 18.3.1 eSPI mode register (ESPI\_SPMODE)

The eSPI mode register (SPMODE) controls eSPI general operation mode.





### **ESPI\_SPMODE** field descriptions

| Field     | Description                                                                                                                                                                                                                                |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0<br>EN   | Enable eSPI. Any bits in SPMODE must not change when EN is set.                                                                                                                                                                            |  |  |
|           | O The eSPI is disabled. The eSPI is in a idle state and consumes minimal power. The eSPI BRG is not functioning and the input clock is disabled.                                                                                           |  |  |
|           | 1 The eSPI is enabled.                                                                                                                                                                                                                     |  |  |
| 1<br>LOOP | Loop mode. Enables local loopback operation.                                                                                                                                                                                               |  |  |
|           | 0 Normal operation.                                                                                                                                                                                                                        |  |  |
|           | 1 Loopback mode. Used to test the eSPI controller internal functionality, the transmitter output is<br>internally connected to the receiver input. The receiver and transmitter operate normally, except that<br>received data is ignored. |  |  |
| 2–12<br>- | This field is reserved. Reserved                                                                                                                                                                                                           |  |  |
| 13–15     | Data output hold adjustment. This field can be used for RapidS.                                                                                                                                                                            |  |  |
| HO_ADJ    | 000 Output data is delayed by an extra 3 platform clock cycles                                                                                                                                                                             |  |  |
|           | 001 Output data is delayed by an extra 1 platform clock cycles                                                                                                                                                                             |  |  |
|           | 010 Output data is delayed by an extra 2 platform clock cycles                                                                                                                                                                             |  |  |
|           | 011 Output data is delayed by an extra 3 platform clock cycles                                                                                                                                                                             |  |  |
|           | 100 Output data is delayed by an extra 4 platform clock cycles                                                                                                                                                                             |  |  |
|           | 101 Output data is delayed by an extra 5 platform clock cycles                                                                                                                                                                             |  |  |
|           | 110 Output data is delayed by an extra 6 platform clock cycles                                                                                                                                                                             |  |  |
|           | 111 Output data is delayed by an extra 7 platform clock cycles                                                                                                                                                                             |  |  |

Table continues on the next page...

### Enhanced serial peripheral interface (eSPI) memory map

# **ESPI\_SPMODE** field descriptions (continued)

| Field          | Description                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------|
| 16–17<br>-     | This field is reserved. Reserved                                                                                    |
| 18–23<br>TXTHR | Tx FIFO threshold-if Tx FIFO has less than TXTHR bytes, an interrupt can be issued to the core.  Valid values: 1-32 |
| 24–26<br>-     | This field is reserved. Reserved                                                                                    |
| 27–31<br>RXTHR | Rx FIFO threshold-if Rx FIFO has more than RXTHR bytes, an interrupt can be issued to the core.  Valid values: 0-31 |

# 18.3.2 eSPI event register (ESPI\_SPIE)

The eSPI event register (SPIE) generates interrupts and reports events recognized by the eSPI. When an event is recognized, the eSPI sets the corresponding SPIE bit. Clear SPIE bits by writing a 1-writing 0 has no effect. Setting a bit in the eSPI mask register (SPIM) enables interrupt and clearing a bit masks the corresponding interrupt. Unmasked SPIE bits must be cleared before the core clears internal interrupt requests. Bits RNE and TNF are status bits. Fields RXCNT and TXCNT hold Rx and Tx FIFOS' statuses. They are not cleared as a result of writing to SPIE.





#### Enhanced serial peripheral interface (eSPI) memory map



# **ESPI\_SPIE** field descriptions

| Field          | Description                                                                                                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0–1<br>-       | This field is reserved. Reserved, should be cleared.                                                                                 |
| 2–7<br>RXCNT   | The current number of full Rx FIFO bytes  NOTE: For character lengths of 9 to 16 bits-each character occupies 2 bytes in Rx/Tx FIFO. |
| 8–9<br>-       | This field is reserved. Reserved, should be cleared.                                                                                 |
| 10–15<br>TXCNT | The current number of free Tx FIFO bytes  NOTE: For character lengths of 9 to 16 bits-each character occupies 2 bytes in Rx/Tx FIFO  |
| 16<br>TXE      | Tx FIFO is empty                                                                                                                     |
| 17<br>DON      | Last character was transmitted.  The last character was transmitted and a new command can be written for the next frame              |
| 18<br>RXT      | Rx FIFO has more than RXTHR bytes, that is, at least RXTHR + 1 bytes                                                                 |
| 19<br>RXF      | Rx FIFO is full                                                                                                                      |

Table continues on the next page...

### **ESPI\_SPIE** field descriptions (continued)

| Field      | Description                                                                                                                                                                                        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20<br>TXT  | Tx FIFO has less than TXTHR bytes, that is, at most TXTHR - 1 bytes                                                                                                                                |
| 21 -       | This field is reserved. Reserved, should be cleared.                                                                                                                                               |
| 22<br>RNE  | Not empty. Indicates that the Rx FIFO register contains a received character.  The Rx FIFO is empty  The Rx FIFO has a received character. The core can read the content of Rx FIFO through SPIRF. |
| 23<br>TNF  | Tx FIFO not full.  0 The transmitter FIFO is full.  1 The transmitter FIFO is not full.                                                                                                            |
| 24–31<br>- | This field is reserved. Reserved, should be cleared.                                                                                                                                               |

# 18.3.3 eSPI mask register (ESPI\_SPIM)

The eSPI mask register (SPIM) enables/masks interrupts for events recognized by the eSPI. When an event is recognized, the eSPI sets the corresponding SPIE bit. Setting a bit in the eSPI mask register (SPIM) enables and clearing a bit masks the corresponding interrupt. Unmasked SPIE bits must be cleared before the core clears internal interrupt requests.

Bits RNE and TNF in SPIM are status bits. They are not cleared as a result of writing to SPIM.

#### Enhanced serial peripheral interface (eSPI) memory map Address: 7000h base + 8h offset = 7008h R Reserved W Reset Bit Ŧ R Reserved TXE DON RXT RXF TXT Reserved W Reset

#### **ESPI\_SPIM** field descriptions

| Field      | Description                                                                                                                              |
|------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>-  | This field is reserved. Reserved, should be cleared.                                                                                     |
| 16<br>TXE  | Tx FIFO empty interrupt mask  Tx FIFO empty interrupt mask  TXE event will not cause eSPI Interrupt  TXE event will cause eSPI Interrupt |
| 17<br>DON  | Last character transmitted mask  0 DON event will not cause eSPI Interrupt  1 DON event will cause eSPI Interrupt                        |
| 18<br>RXT  | Rx threshold interrupt mask  0 RXT event will not cause eSPI Interrupt  1 RXT event will cause eSPI Interrupt                            |
| 19<br>RXF  | Rx FIFO full interrupt mask  0 RXF event will not cause eSPI Interrupt  1 RXF event will cause eSPI Interrupt                            |
| 20<br>TXT  | Tx threshold interrupt mask  Tx threshold interrupt mask  TxT event will not cause eSPI Interrupt  TXT event will cause eSPI Interrupt   |
| 21         | This field is reserved. Reserved, should be cleared.                                                                                     |
| 22<br>RNE  | Rx not empty interrupt mask  O Not Empty event will not cause eSPI Interrupt  1 Not Empty event will cause eSPI Interrupt                |
| 23<br>TNF  | Tx not full interrupt mask  O Not full event will not cause eSPI Interrupt  1 Not full event will cause eSPI Interrupt                   |
| 24–31<br>- | This field is reserved. Reserved, should be cleared.                                                                                     |

# 18.3.4 eSPI command register (ESPI\_SPCOM)

The eSPI command register (SPCOM) is used by the host to supply information on the new frame.

After SPCOM has been written to initiate the first transaction after startup, commands can be executed only after SPIE[DON] is set. Otherwise they are ignored.

A transaction can be full duplex (regular eSPI) or half duplex. Half duplex can be used for example for write accesses to a flash (only transmit) or for a read access from a flash (first part is transmit without receive, while the second part is receive without transmit).

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Enhanced serial peripheral interface (eSPI) memory map

Address: 7000h base + Ch offset = 700Ch

0

Reset



### **ESPI\_SPCOM** field descriptions

0

0

0

0

0

| Field     | Description                                                                                           |  |  |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0–1<br>CS | Chip select-chip select for which transaction is destined                                             |  |  |  |  |  |  |  |  |
|           | 00 SPI_CS0_B                                                                                          |  |  |  |  |  |  |  |  |
|           | 01 SPI_CS1_B                                                                                          |  |  |  |  |  |  |  |  |
|           | 10 SPI_CS2_B                                                                                          |  |  |  |  |  |  |  |  |
|           | 11 SPI_CS3_B                                                                                          |  |  |  |  |  |  |  |  |
| 2         | RxDelay                                                                                               |  |  |  |  |  |  |  |  |
| RxDelay   | 0 Normal eSPI operation                                                                               |  |  |  |  |  |  |  |  |
|           | 1 Rx data should be sampled a bit later than regular eSPI (used for full cycle operation such as with |  |  |  |  |  |  |  |  |
| 3         | Atmel RapidS devices)  This mode is useful only for character lengths of 4,6,8.                       |  |  |  |  |  |  |  |  |
| DO        |                                                                                                       |  |  |  |  |  |  |  |  |
|           | DO and RapidS should not be set simultaneously.                                                       |  |  |  |  |  |  |  |  |
|           | 0 Normal eSPI operation                                                                               |  |  |  |  |  |  |  |  |
|           | 1 Winbond dual output read-when eSPI master reads data 2 data bits are available (on MISO and         |  |  |  |  |  |  |  |  |
|           | MOSI)                                                                                                 |  |  |  |  |  |  |  |  |
| 4<br>TO   | Transmit only                                                                                         |  |  |  |  |  |  |  |  |
|           | 1 No reception is done for the frame (useful for write transactions)                                  |  |  |  |  |  |  |  |  |
|           | 0 Normal operation                                                                                    |  |  |  |  |  |  |  |  |
| 5         | HLD                                                                                                   |  |  |  |  |  |  |  |  |
| HLD       | O. Normal eneration                                                                                   |  |  |  |  |  |  |  |  |
|           | Normal operation     Mack first generated SPL CLK. Should be used only for RapidS mode?               |  |  |  |  |  |  |  |  |
|           | 1 Mask first generated SPI_CLK. Should be used only for RapidS mode0                                  |  |  |  |  |  |  |  |  |

Table continues on the next page...

#### **ESPI\_SPCOM** field descriptions (continued)

| Field            | Description                                                                                                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6–7<br>-         | This field is reserved. Reserved, should be cleared.                                                                                                                                                                            |
| 8–15<br>RxSKIP   | If (RXSKIP ≠ 0)-Number of characters skipped for reception from frame start.  Non-zero values of RxSKIP force the eSPI to half-duplex mode, and therefore this causes TRANLEN-RxSKIP characters to be skipped for transmission. |
|                  | RXSKIP is useful for reads of SPI Flash memories where the first valid read data is received several characters after the transmission begins (after the eSPI has transmitted an instruction opcode and address).               |
|                  | <b>NOTE:</b> If TO = 1, RxSKIP must be set to 0.                                                                                                                                                                                |
|                  | <b>NOTE:</b> If RXSKIP = 0 and TO = 0, the eSPI changes to full duplex mode.                                                                                                                                                    |
| 16–31<br>TRANLEN | Transaction length - (number of characters in the frame - 1)                                                                                                                                                                    |

# 18.3.5 eSPI transmit FIFO access register (ESPI\_SPITF)

The 32-bit write-only eSPI transmit FIFO access register (SPITF) holds the characters to be written to the transmit FIFO. The number of bits in each character is specified by SPMODEx[LENx]. Each time SPIE[TNF] is set, the core can write more data to the SPITF register, if there is no error indication in the SPIE.

For character lengths of 4 to 8 bits, SPITF contains up to 4 characters (unless end of frame). The lsbs are in bits 7, 15, 23, and 31 of SPITF.

For character lengths of 9 to 16 bits, SPITF contains up to 2 characters (unless end of frame). For 16 bits with SPMODEx[REVx] = 1, the lsb is in bits 15 and 31 of SPITF. For other options, lsbs are in bits 7 and 23 while msbs are in bits (23-LENx) and (39-LENx) of SPITF.

For example: REV = 0, LEN = 10 (0xA), SPITF[0-15] = 0xFB05-bitstream is: (lsb first) 11011111101 (msb last).

#### **NOTE**

The user must write N bytes of SPITF  $(1 \le N \le 4)$  that do not exceed the number of free bytes in the transmit FIFO. It is valid for the user to write only 1 or 2 bytes of SPITF (at offset 0x010) if the user wishes to write fewer characters than the maximum supported by SPITF for the particular character length in use.

The following figures show examples of the contents of SPITF with various parameters set.

#### Enhanced serial peripheral interface (eSPI) memory map

### SPITF Example - SPMODEx[REVx]=0, SPMODEx[LENx]=3, LSB Sent First:

|   | 0 3 | 4        | 5 6       | 7    | 8 11 | 12       | 13 14     | 15   | 16 19 | 20       | 21 22     | 23   | 24 27 | 28       | 29 30     | 31   |
|---|-----|----------|-----------|------|------|----------|-----------|------|-------|----------|-----------|------|-------|----------|-----------|------|
| R |     |          |           |      |      |          |           |      |       |          |           |      |       |          |           |      |
| W | -   | MSB<br>0 | Data<br>0 | LSB0 | -    | MSB<br>1 | Data<br>1 | LSB1 | -     | MSB<br>2 | Data<br>2 | LSB2 | -     | MSB<br>3 | Data<br>3 | LSB3 |

### SPITF Example - SPMODEx[REVx]=x, SPMODEx[LENx]=7:

|   | 0    | 1 6    | 7        | 8    | 9 14   | 15       | 16   | 17   | 22 | 23       | 24   | 30     | 31       |
|---|------|--------|----------|------|--------|----------|------|------|----|----------|------|--------|----------|
| R |      |        |          |      |        |          |      |      |    |          |      |        |          |
| W | MSB0 | Data 0 | LSB<br>0 | MSB1 | Data 1 | LSB<br>1 | MSB2 | Data | 2  | LSB<br>2 | MSB3 | Data 3 | LSB<br>3 |

### SPITF Example - SPMODEx[REVx]=0, SPMODEx[LENx]=10, LSB Sent First:

|   | 0 6               | 7    | 8 12 | 13       | 14 15             | 16 22          | 23   | 24 28 | 29       | 30 31             |
|---|-------------------|------|------|----------|-------------------|----------------|------|-------|----------|-------------------|
| R |                   |      |      |          |                   |                |      |       |          |                   |
| w | Data 0 LS<br>Byte | LSB0 | -    | MSB<br>0 | Data 0 MS<br>Byte | Data 1 LS Byte | LSB1 | -     | MSB<br>1 | Data 1 MS<br>Byte |

# SPITF Example - SPMODEx[REVx]=1, SPMODEx[LENx]=15, MSB Sent First:



Address: 7000h base + 10h offset = 7010h



#### **ESPI\_SPITF** field descriptions

| Field        | Description              |
|--------------|--------------------------|
| 0–31<br>DATA | Varies as parameters set |

# 18.3.6 eSPI receive FIFO access register (ESPI\_SPIRF)

The 32-bit read-only eSPI receive data register (SPIRF) is used to hold characters read from the receive FIFO. Each time SPIE[RNE] is set, the core can read the SPIRF register.

For character lengths of 4 to 8 bits, SPIRF contains up to 4 characters. The msbs are in bits 0, 8, 16, and 24. For character lengths of 9 to 16 bits, SPIRF contains up to 2 characters. The msbs are in bits 0 and 16. SPMODEx[REVx] does not affect the msb or lsb bit positions when reading the SPIRF register.

The user must read N bytes of SPIRF ( $1 \le N \le 4$ ) that do not exceed the amount of data in the receive FIFO. The user can read less bytes than the amount of data in the receive FIFO. For example, a 1-byte read of SPIRF when configured for 8-bit characters with 4 characters of data in the receive FIFO results in the 3 unread characters shuffling down to the lower 24 bits of SPIRF in preparation for the following SPIRF read.

### SPIRF Example - SPMODEx[LENx]=3

|   | 0    | 1 2       | 3        | 4 7 | 8    | 9 10   | 11       | 12 15 | 16   | 17 18     | 19       | 20 23 | 24   | 25 26     | 27       | 28 31 |
|---|------|-----------|----------|-----|------|--------|----------|-------|------|-----------|----------|-------|------|-----------|----------|-------|
| R | MSB0 | Data<br>0 | LS<br>B0 | -   | MSB1 | Data 1 | LSB<br>1 | -     | MSB2 | Data<br>2 | LSB<br>2 | -     | MSB3 | Data<br>3 | LSB<br>3 | -     |
| W |      |           |          |     |      |        |          |       |      |           |          |       |      |           |          |       |

### SPIRF Example - SPMODEx[LENx]=10:

|   | 0        | 1 7               | 8 9            | 10   | 11 15 | 16       | 17 23             | 24 25          | 26   | 27 31 |  |
|---|----------|-------------------|----------------|------|-------|----------|-------------------|----------------|------|-------|--|
| R | MSB<br>0 | Data 0 MS<br>Byte | Data 0 LS Byte | LSB0 | -     | MSB<br>1 | Data 1 MS<br>Byte | Data 1 LS Byte | LSB1 | -     |  |
| W |          |                   |                |      |       |          |                   |                |      |       |  |

### SPIRF Example - SPMODEx[LENx]=15:



#### Enhanced serial peripheral interface (eSPI) memory map

Address: 7000h base + 14h offset = 7014h



#### **ESPI\_SPIRF** field descriptions

| Field        | Description              |
|--------------|--------------------------|
| 0–31<br>DATA | Varies as parameters set |

# 18.3.7 eSPI CS0 mode register (ESPI\_SPMODE0)

The eSPI CS0 mode register (SPMODE0) controls eSPI master operation with chip select 0.

Address: 7000h base + 20h offset = 7020h



#### ESPI\_SPMODE0 field descriptions

| Field    | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| 0<br>CI0 | Clock invert. Inverts eSPI clock polarity. See Figure 18-13 and Figure 18-14 for more information |
|          | 0 The inactive state of SPI_CLK is low.                                                           |
|          | 1 The inactive state of SPI_CLK is high.                                                          |
| 1        | Clock phase. Selects the transfer format. See Figure 18-13 and Figure 18-14 for more information. |
| CP0      |                                                                                                   |
|          | 0 SPI_CLK starts toggling at the middle of the data transfer.                                     |
|          | 1 SPI_CLK starts toggling at the beginning of the data transfer.                                  |

Table continues on the next page...

# **ESPI\_SPMODE0** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2             | Reverse data mode. Determines the receive and transmit character bit order.                                                                                                                                                                                                                                                                                                                                                       |
| REV0          | 0 Isb of the character sent and received first                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 1 msb of the character sent and received first-for 8/16 bits data character only                                                                                                                                                                                                                                                                                                                                                  |
| 3<br>DIV160   | Divide by 16. Selects the clock source for the eSPI baud rate generator (eSPI BRG) when configured as an eSPI master.                                                                                                                                                                                                                                                                                                             |
|               | NOTE: System clock as used here is defined to be platform clock divided by 2.                                                                                                                                                                                                                                                                                                                                                     |
|               | 0 System clock is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 1 System clock/16 is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                   |
| 4–7<br>PM0    | Prescale modulus select. Specifies the divide ratio of the prescale divider in the eSPI clock generator. The eSPI baud rate generator clock source (either system clock or system clock divided by 16, depending on DIV16 bit) is divided by 2 x ([PM] + 1), a range from 2 to 32. For example, if the prescale modulus is set to PM=0x0011 and DIV16 is set, the SPI_CLK/system clock rate will be 16 x (2 x (0x0011 + 1)) = 128 |
|               | NOTE: System clock as used here is defined to be platform clock divided by 2                                                                                                                                                                                                                                                                                                                                                      |
| 8<br>ODD0     | NOTE: Odd bit can be set only if resulting high/low clock phases do not violate high/low timing specification of SPI Flash.                                                                                                                                                                                                                                                                                                       |
|               | 0 Even division - 2 x (PM + 1) x (15 x DIV16 + 1) - 50% duty cycle<br>1 Odd division - (2 x PM + 1) x (15 x DIV16 + 1) (except for PM = 0 where it divides by 2 x (7 x DIV16 + 1)); duty cycle is (PM + 1) ÷ (2 x PM + 1) for DIV16 = 0; duty cycle is 50% for DIV16 = 1.                                                                                                                                                         |
| 9–10<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11            | CS0 Polarity.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| POL0          | 1 Asserted Low, Negated High                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 0 Asserted High, Negated Low.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12–15<br>LEN0 | Character length in bits per character. Supports a range from 1-bit to 16-bit data characters. Must be between 00011 (4 bits) and 01111 (16 bits). A value less than 4 causes erratic behavior.                                                                                                                                                                                                                                   |
| 16–19         | CS assertion time in bits before frame start (that is, before clock toggles)                                                                                                                                                                                                                                                                                                                                                      |
| CS0BEF        | Example: CS0BEF = 0010 inserts 2 bits time gap between CS0 assertion to clock toggle                                                                                                                                                                                                                                                                                                                                              |
| 20–23         | CS assertion time in bits after frame end (that is, after clock finishes toggling)                                                                                                                                                                                                                                                                                                                                                |
| CS0AFT        | Example: CS0AFT = 0010 inserts 2 bits time gap between clock stop to CS0 negation                                                                                                                                                                                                                                                                                                                                                 |
| 24–28         | Clock gap                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CS0CG         | insert gaps between transmitted frames according to this size (during this time, chip select is negated).                                                                                                                                                                                                                                                                                                                         |
|               | Chip select is negated minimum time of 1 bit time.                                                                                                                                                                                                                                                                                                                                                                                |
|               | Example: CS0CG = 00101 inserts 5 + 1 = 6 bits time gap between every two consecutive frames                                                                                                                                                                                                                                                                                                                                       |
| 29–31<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |

# 18.3.8 eSPI CS1 mode register (ESPI\_SPMODE1)

The eSPI CS1 mode register (SPMODE1) controls eSPI master operation with chip select 1.

Address: 7000h base + 24h offset = 7024h



### **ESPI\_SPMODE1** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>CI1    | Clock invert. Inverts eSPI clock polarity. See Figure 18-13 and Figure 18-14 for more information                                                                                                                                                                                                                                                                                                                                   |
|             | 0 The inactive state of SPI_CLK is low.                                                                                                                                                                                                                                                                                                                                                                                             |
|             | 1 The inactive state of SPI_CLK is high.                                                                                                                                                                                                                                                                                                                                                                                            |
| 1<br>CP1    | Clock phase. Selects the transfer format. See Figure 18-13 and Figure 18-14 for more information.                                                                                                                                                                                                                                                                                                                                   |
|             | 0 SPI_CLK starts toggling at the middle of the data transfer.                                                                                                                                                                                                                                                                                                                                                                       |
|             | 1 SPI_CLK starts toggling at the beginning of the data transfer.                                                                                                                                                                                                                                                                                                                                                                    |
| 2<br>REV1   | Reverse data mode. Determines the receive and transmit character bit order.                                                                                                                                                                                                                                                                                                                                                         |
|             | 0 Isb of the character sent and received first                                                                                                                                                                                                                                                                                                                                                                                      |
|             | 1 msb of the character sent and received first-for 8/16 bits data character only                                                                                                                                                                                                                                                                                                                                                    |
| 3<br>DIV161 | Divide by 16. Selects the clock source for the eSPI baud rate generator (eSPI BRG) when configured as an eSPI master.                                                                                                                                                                                                                                                                                                               |
|             | NOTE: System clock as used here is defined to be platform clock divided by 2.                                                                                                                                                                                                                                                                                                                                                       |
|             | 0 System clock is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 1 System clock/16 is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                     |
| 4–7<br>PM1  | Prescale modulus select. Specifies the divide ratio of the prescale divider in the eSPI clock generator. The eSPI baud rate generator clock source (either system clock or system clock divided by 16, depending on DIV16 bit) is divided by 2 x ([PM] + 1), a range from 2 to 32. For example, if the prescale modulus is set to PM = 0x0011 and DIV16 is set, the SPI_CLK/system clock rate will be 16 x (2 x (0x0011 + 1)) = 128 |

Table continues on the next page...

# **ESPI\_SPMODE1** field descriptions (continued)

| Field           | Description                                                                                                                                                                                       |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | NOTE: System clock as used here is defined to be platform clock divided by 2.                                                                                                                     |
| 8<br>ODD1       | NOTE: Odd bit can be set only if resulting high/low clock phases do not violate high/low timing specification of SPI Flash.                                                                       |
|                 | 0 Even division-2 x (PM + 1) x (15 x DIV16 + 1) - 50% duty cycle                                                                                                                                  |
|                 | 1 Odd division-(2 x PM + 1) x (15 x DIV16 + 1) (except for PM = 0 where it divides by 2 x (7 x DIV16 + 1)); duty cycle is (PM + 1) ÷ (2 x PM + 1) for DIV16 = 0; duty cycle is 50% for DIV16 = 1. |
| 9–10<br>-       | This field is reserved. Reserved                                                                                                                                                                  |
| 11<br>POL1      | CS1 Polarity.  1 Asserted Low, Negated High  0 Asserted High, Negated Low.                                                                                                                        |
| 12–15<br>LEN1   | Character length in bits per character. Supports a range from 1-bit to 16-bit data characters. Must be between 00011 (4 bits) and 01111 (16 bits). A value less than 4 causes erratic behavior.   |
| 16-19<br>CS1BEF | CS assertion time in bits before frame start (that is, before clock toggles)                                                                                                                      |
|                 | Example: CS1BEF = 0010 inserts 2 bits time gap between CS1 assertion to clock toggle.                                                                                                             |
| 20–23<br>CS1AFT | CS assertion time in bits after frame end (that is, after clock finishes toggling)                                                                                                                |
|                 | Example: CS1AFT = 0010 inserts 2 bits time gap between clock stop to CS1 negation.                                                                                                                |
| 24–28           | Clock Gap                                                                                                                                                                                         |
| CS1CG           | insert gaps between transmitted frames according to this size (during this time, chip select is negated).                                                                                         |
|                 | Chip select is negated minimum time of 1 bit time.                                                                                                                                                |
|                 | Example: CS1CG = 00101 inserts 5 + 1 = 6 bits time gap between every two consecutive frames.                                                                                                      |
| 29–31<br>-      | This field is reserved. Reserved                                                                                                                                                                  |

# 18.3.9 eSPI CS2 mode register (ESPI\_SPMODE2)

The eSPI CS2 mode register (SPMODE2) controls the eSPI master operation with chip select 2.

Address: 7000h base + 28h offset = 7028h



# **ESPI\_SPMODE2** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>Cl2    | Clock invert. Inverts eSPI clock polarity. See Figure 18-13 and Figure 18-14 for more information                                                                                                                                                                                                                                                                                                                                    |
|             | 0 The inactive state of SPI_CLK is low.                                                                                                                                                                                                                                                                                                                                                                                              |
|             | 1 The inactive state of SPI_CLK is high.                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>CP2    | Clock phase. Selects the transfer format. See Figure 18-13 and Figure 18-14 for more information.                                                                                                                                                                                                                                                                                                                                    |
|             | 0 SPI_CLK starts toggling at the middle of the data transfer.                                                                                                                                                                                                                                                                                                                                                                        |
|             | 1 SPI_CLK starts toggling at the beginning of the data transfer.                                                                                                                                                                                                                                                                                                                                                                     |
| 2<br>REV2   | Reverse data mode. Determines the receive and transmit character bit order.                                                                                                                                                                                                                                                                                                                                                          |
|             | 0 Isb of the character sent and received first                                                                                                                                                                                                                                                                                                                                                                                       |
|             | 1 msb of the character sent and received first-for 8/16 bits data character only                                                                                                                                                                                                                                                                                                                                                     |
| 3<br>DIV162 | Divide by 16. Selects the clock source for the eSPI baud rate generator (eSPI BRG) when configured as an eSPI master.                                                                                                                                                                                                                                                                                                                |
|             | NOTE: System clock as used here is defined to be platform clock divided by 2.                                                                                                                                                                                                                                                                                                                                                        |
|             | 0 System clock is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                         |
|             | 1 System clock/16 is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                      |
| 4–7<br>PM2  | Prescale modulus select. Specifies the divide ratio of the prescale divider in the eSPI clock generator. The eSPI baud rate generator clock source (either system clock or system clock divided by 16, depending on DIV16 bit) is divided by 2 x ([PM] + 1), a range from 2 to 32. For example, if the prescale modulus is set to PM = 0x0011 and DIV16 is set, the system clock/SPI_CLK ratio will be 16 x (2 x (0x0011 + 1)) = 128 |

Table continues on the next page...

## **ESPI\_SPMODE2** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                             |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | NOTE: System clock as used here is defined to be platform clock divided by 2.                                                                                                                                                           |
| 8             |                                                                                                                                                                                                                                         |
| ODD2          | NOTE: Odd bit can be set only if resulting high/low clock phases do not violate high/low timing specification of SPI Flash.                                                                                                             |
|               | 0 Even division-2 x (PM + 1) x (15 x DIV16 + 1) - 50% duty cycle                                                                                                                                                                        |
|               | Odd division- $(2 \times PM + 1) \times (15 \times DIV16 + 1)$ (except for PM = 0 where it divides by $2 \times (7 \times DIV16 + 1)$ ); duty cycle is $(PM + 1) \div (2 \times PM + 1)$ for DIV16 = 0; duty cycle is 50% for DIV16 = 1 |
| 9–10<br>-     | This field is reserved. Reserved                                                                                                                                                                                                        |
| 11<br>POL2    | CS2 Polarity.                                                                                                                                                                                                                           |
|               | <ul><li>1 Asserted Low, Negated High</li><li>0 Asserted High, Negated Low.</li></ul>                                                                                                                                                    |
| 12–15<br>LEN2 | Character length in bits per character. Supports a range from 1-bit to 16-bit data characters. Must be between 00011 (4 bits) and 01111 (16 bits). A value less than 4 causes erratic behavior.                                         |
| 16–19         | CS assertion time in bits before frame start (that is, before clock toggles)                                                                                                                                                            |
| CS2BEF        | Example: CS2BEF = 0010 inserts 2 bits time gap between CS2 assertion to clock toggle                                                                                                                                                    |
| 20–23         | CS assertion time in bits after frame end (that is, after clock finishes toggling)                                                                                                                                                      |
| CS2AFT        | Example: CS2AFT = 0010 inserts 2 bits time gap between clock stop to CS2 negation                                                                                                                                                       |
| 24–28         | Clock Gap                                                                                                                                                                                                                               |
| CS2CG         | insert gaps between transmitted frames according to this size (during this time, chip select is negated).                                                                                                                               |
|               | Chip select is negated minimum time of 1 bit time.                                                                                                                                                                                      |
|               | Example: CS1CG = 00101 inserts 5 + 1 = 6 bits time gap between every two consecutive frames                                                                                                                                             |
| 29–31<br>-    | This field is reserved. Reserved                                                                                                                                                                                                        |

# 18.3.10 eSPI CS3 mode register (ESPI\_SPMODE3)

The eSPI CS3 mode register (SPMODE3) controls the eSPI master operation with chip select 3.

Address: 7000h base + 2Ch offset = 702Ch



## **ESPI\_SPMODE3** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0<br>Cl3    | Clock invert. Inverts eSPI clock polarity. See Figure 18-13 and Figure 18-14 for more information                                                                                                                                                                                                                                                                                                                                             |  |
|             | 0 The inactive state of SPI_CLK is low.                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|             | 1 The inactive state of SPI_CLK is high.                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 1<br>CP3    | Clock phase. Selects the transfer format. See Figure 18-13 and Figure 18-14 for more information.                                                                                                                                                                                                                                                                                                                                             |  |
|             | 0 SPI_CLK starts toggling at the middle of the data transfer.                                                                                                                                                                                                                                                                                                                                                                                 |  |
|             | 1 SPI_CLK starts toggling at the beginning of the data transfer.                                                                                                                                                                                                                                                                                                                                                                              |  |
| 2<br>REV3   | Reverse data mode. Determines the receive and transmit character bit order.                                                                                                                                                                                                                                                                                                                                                                   |  |
|             | 0 Isb of the character sent and received first                                                                                                                                                                                                                                                                                                                                                                                                |  |
|             | 1 msb of the character sent and received first - for 8/16 bits data character only                                                                                                                                                                                                                                                                                                                                                            |  |
| 3<br>DIV163 | Divide by 16. Selects the clock source for the eSPI baud rate generator (eSPI BRG) when configured as an eSPI master.                                                                                                                                                                                                                                                                                                                         |  |
|             | NOTE: System clock as used here is defined to be platform clock divided by 2                                                                                                                                                                                                                                                                                                                                                                  |  |
|             | 0 System clock is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|             | 1 System clock/16 is the input to the eSPI BRG.                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 4–7<br>PM3  | Prescale modulus select. Specifies the divide ratio of the prescale divider in the eSPI clock generator. The eSPI baud rate generator clock source (either system clock or system clock divided by 16, depending on DIV16 bit) is divided by 2 x ( $[PM] + 1$ ), a range from 2 to 32. For example, if the prescale modulus is set to $PM = 0x0011$ and DIV16 is set, the SPI_CLK/system clock rate will be 16 x (2 x ( $0x0011 + 1$ )) = 128 |  |

## **ESPI\_SPMODE3** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | NOTE: System clock as used here is defined to be platform clock divided by 2                                                                                                                                                                                                                         |
| 8<br>ODD3     | NOTE: Odd bit can be set only if resulting high/low clock phases do not violate high/low timing specification of SPI Flash.  0 Even division-2 x (PM + 1) x (15 x DIV16 + 1) - 50% duty cycle 1 Odd division-(2 x PM + 1) x (15 x DIV16 + 1) (except for PM = 0 where it divides by 2 x (7 x DIV16 + |
|               | 1)); duty cycle is $(PM + 1) \div (2 \times PM + 1)$ for DIV16 = 0; duty cycle is 50% for DIV16 = 1                                                                                                                                                                                                  |
| 9–10<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                                                     |
| 11<br>POL3    | CS Polarity.  1 Asserted Low, Negated High 0 Asserted High, Negated Low.                                                                                                                                                                                                                             |
| 12–15<br>LEN3 | Character length in bits per character. Supports a range from 1-bit to 16-bit data characters. Must be between 00011 (4 bits) and 01111 (16 bits). A value less than 4 causes erratic behavior.                                                                                                      |
| 16–19         | CS assertion time in bits before frame start (that is, before clock toggles)                                                                                                                                                                                                                         |
| CS3BEF        | Example: CS3BEF = 0010 inserts 2 bits time gap between CS3 assertion to clock toggle                                                                                                                                                                                                                 |
| 20–23         | CS assertion time in bits after frame end (that is, after clock finishes toggling)                                                                                                                                                                                                                   |
| CS3AFT        | Example: CS3AFT = 0010 inserts 2 bits time gap between clock stop to CS3 negation                                                                                                                                                                                                                    |
| 24–28         | Clock Gap                                                                                                                                                                                                                                                                                            |
| CS3CG         | insert gaps between transmitted frames according to this size (during this time, chip select is negated).                                                                                                                                                                                            |
|               | Chip select is negated minimum time of 1 bit time.                                                                                                                                                                                                                                                   |
|               | Example: CS1CG = 00101 inserts 5 + 1 = 6 bits time gap between every two consecutive frames                                                                                                                                                                                                          |
| 29–31<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                     |

## 18.4 eSPI transfer formats

Figure below shows the eSPI transfer format in which SPI\_CLK starts toggling in the middle of the transfer (SPMODEx[CPx] = 0).



NOTE: Q = Undefined Signal.

Figure 18-13. eSPI transfer format with SPMODEx[CPx] = 0

Figure below shows the eSPI transfer format in which SPI\_CLK starts toggling at the beginning of the transfer (SPMODEx[CPx] = 1).



NOTE: Q = Undefined Signal.

Figure 18-14. eSPI transfer format with SPMODEx[CPx] = 1

## 18.5 Cl and CP values for various eSPI devices

- 1. Regular devices-eSPI mode0-CI = CP = 0
- 2. Regular devices-eSPI mode3-CI = CP = 1

For Winbond devices DO should also be set for dual output read command.

- 3. RapidS mode0-CI = 0, CP = 1, HLD = 1
- 4. RapidS mode3-CI = 1, CP = 0

# 18.6 eSPI programming examples

This section provides eSPI programming examples for 24-bit address memory and 16-bit address memory.

## 18.6.1 24-bit address example

The following sequence initializes the eSPI to read 36 bytes from 24-bit address memory, start address = 0x00 0040:

- 1. Configure a parallel I/O signal to operate as the eSPI CS1 output signal.
- 2. Write 0xFFFF\_FFFF to SPIE to clear any previous events. Configure SPIM to enable all desired eSPI interrupts.
- 3. Configure SPMODE =  $0x8000\_100F$  to enable normal operation, eSPI enabled.
- 4. Configure SPMODE1 = 0x2417\_1108-REV1 = 1, PM1 = 4 (divide eSPI input clock by 10), LEN1 = 7, POL1 = 1, CS1BEF = CS1AFT = CS1CG = 1.
- 5. Configure SPITF =  $0x0300\_0040-0x03$  is read opcode while  $0x00\_0040$  is the 24-bit start address.
- 6. Configure SPCOM =  $0x0004\_0027$  so 4 bytes are skipped (1 for opcode and 3 for 24-bit address), TRANLEN = 36 + 4 1.

## 18.6.2 16-bit address example

The following sequence initializes the eSPI to read 36 bytes from 16-bit address memory, start address = 0x0040:

- 1. Configure a parallel I/O signal to operate as the eSPI CS1 output signal.
- 2. Write 0xFFFF\_FFFF to SPIE to clear any previous events. Configure SPIM to enable all desired eSPI interrupts.
- 3. Configure SPMODE =  $0x8000\_100F$  to enable normal operation, eSPI enabled.
- 4. Configure SPMODE1 =  $0x2417_1108$ -REV1 = 1, PM1 = 4 (divide eSPI input clock by 10), LEN1 = 7, POL1 = 1, CS1BEF = CS1AFT = CS1CG = 1.
- 5. Configure SPITF =  $0x0300\_40xx$  (xx is don't care)-0x03 is read opcode while 0x0040 is the 16-bit start address.
- 6. Configure SPCOM =  $0x0003\_0026$  so 3 bytes are skipped (1 for opcode and 2 for 16-bit address), TRANLEN = 36 + 3 1.

eSPI programming examples

# **Chapter 19 Device Performance Monitor**

This chapter describes the device performance monitor facility, which can be used to monitor and optimize performance.

## 19.1 Introduction

This chapter describes the device performance monitor facility, which can be used to monitor and optimize performance.

The e500 core implements a separate performance monitor for strictly core-related behavior, such as instruction timing and L1 cache operations. This is described in the *PowerPC e500 Core Reference Manual* (Freescale Document Order No. E500CORERM).

Performance monitor events, briefly describes the events that can be monitored. Refer to the individual chapters for a better understanding of these events.

The device-level performance monitor facility that can be used to monitor and record selected behaviors of the integrated device. Although the performance monitor described here is similar in many respects to the performance monitor facility implemented on the e500 core, it differs in that it is implemented using memory-mapped registers and it counts events outside the e500 core, for example, DDR and L2 cache events.

Performance monitor counters (PMC0-PMC11) are used to count events selected by the performance monitor local control registers. PMC0 is a 64-bit counter specifically designated to count cycles. PMC1-PMC11 are 32-bit counters that can monitor 64 counter-specific events in addition to counting 64 reference events.

The benefits of the on-chip performance monitor include the following:

• Because some systems or software environments are not easily characterized by signal traces or benchmarks, the performance monitor can be used to understand the P1021 behavior in any system or software environment.

#### Introduction

- The performance monitor facility can be used to aid system developers when bringing up and debugging systems.
- System performance can be increased by monitoring memory hierarchy behavior. This can help to optimize algorithms used to schedule or partition tasks and to refine the data structures and distribution used by each task.

### **19.1.1 Overview**

The figure below is a high-level block diagram of the performance monitor, which consists of a global control register (PMGC0), one 64-bit counter (PMC0), eleven 32-bit counters, and two control registers per counter (24 total control registers).

The global control register PMGC0 affects all counters and takes priority over local control registers. The local control registers are divided into two groups, as follows:

- Local control A registers control counter freezing, overflow condition enable, event selection, and burstiness. Local control register PMLCA0, which controls counter PMC0, does not contain event selection because PMC0 counts only cycles.
- Local control B registers control the start and stop triggering, contain the counters'
  threshold values, and the value of the threshold multiplier. Local control register
  PMLCB0, which controls PMC0, does not contain threshold information because
  PMC0 only counts cycles.



Figure 19-1. Performance monitor block diagram

Performance monitor events are signalled by the functional blocks in the integrated device and are selectively recorded in the PMCs. Sixty-four of these events are referred to as reference events, which can be counted on any of the eleven 32-bit counters. Counter-specific events can be counted only on the counter where the event is defined.

The performance monitor can generate an interrupt on overflow. Several control registers specify how a performance monitor interrupt is signalled. The PMCs can also be programmed to freeze when an interrupt is signalled.

## 19.1.2 Features

The P1021 performance monitor offers a rich set of features that permits a complete performance characterization of the implementation.

These features include:

- One 64-bit counter exclusively dedicated to counting cycles
- Eleven 32-bit counters that count the occurrence of selected events

#### Signal descriptions

- One global control register (affects all counters) and two local control registers per counter
- Ability to count up to 64 reference events that may be counted on any of the eleven 32-bit counters
- Ability to count up to 704 counter-specific events
- Triggering and chaining capability
- Duration and quantity threshold counting
- Burstiness feature that permits counting of burst events with a programmable time between bursts
- Ability to generate an interrupt on overflow

# 19.2 Signal descriptions

The performance monitor does not have any signals that are driven externally (off-chip) but it does assert the internal interrupt (*int*) signal on a performance monitor interrupt condition.

# 19.3 PERFMON Memory Map/Register Definition

Performance monitor registers reside in the run-time register block starting at offset 0x E\_1 000. Undefined 4-byte address spaces within offset 0x000-0xFFF are reserved. This section describes the registers implemented to support the performance monitor facilities.

In addition to these registers, the interrupt control provides four pairs of mask registers that can be used to monitor message, interprocessor, timer, and external interrupts. See Performance monitor mask registers (PMMRs).

### **PERFMON memory map**

| Offset<br>address<br>(hex) | Register name                                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_1000                     | Performance monitor global control register (PERFMON_PMGC0)    | 32                 | R/W    | 0000_0000h  | 19.3.1/1488      |
| E_1010                     | Performance monitor local control register A0 (PERFMON_PMLCA0) | 32                 | R/W    | 0000_0000h  | 19.3.2/1489      |
| E_1014                     | Performance monitor local control register B0 (PERFMON_PMLCB0) | 32                 | R/W    | 0000_0000h  | 19.3.3/1490      |
| E_1018                     | Performance monitor counter 0 lower (PERFMON_PMC0_upper)       | 32                 | R/W    | 0000_0000h  | 19.3.4/1491      |

## **PERFMON** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|----------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_101C                     | Performance monitor counter 0 upper (PERFMON_PMC0_lower)       | 32                 | R/W    | 0000_0000h  | 19.3.5/1492      |
| E_1020                     | Performance monitor local control register An (PERFMON_PMLCA1) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1024                     | Performance monitor local control register Bn (PERFMON_PMLCB1) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1028                     | Performance monitor counter n (PERFMON_PMC1)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1030                     | Performance monitor local control register An (PERFMON_PMLCA2) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1034                     | Performance monitor local control register Bn (PERFMON_PMLCB2) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1038                     | Performance monitor counter n (PERFMON_PMC2)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1040                     | Performance monitor local control register An (PERFMON_PMLCA3) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1044                     | Performance monitor local control register Bn (PERFMON_PMLCB3) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1048                     | Performance monitor counter n (PERFMON_PMC3)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1050                     | Performance monitor local control register An (PERFMON_PMLCA4) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1054                     | Performance monitor local control register Bn (PERFMON_PMLCB4) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1058                     | Performance monitor counter n (PERFMON_PMC4)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1060                     | Performance monitor local control register An (PERFMON_PMLCA5) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1064                     | Performance monitor local control register Bn (PERFMON_PMLCB5) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1068                     | Performance monitor counter n (PERFMON_PMC5)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1070                     | Performance monitor local control register An (PERFMON_PMLCA6) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1074                     | Performance monitor local control register Bn (PERFMON_PMLCB6) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1078                     | Performance monitor counter n (PERFMON_PMC6)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1080                     | Performance monitor local control register An (PERFMON_PMLCA7) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1084                     | Performance monitor local control register Bn (PERFMON_PMLCB7) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1088                     | Performance monitor counter n (PERFMON_PMC7)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_1090                     | Performance monitor local control register An (PERFMON_PMLCA8) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_1094                     | Performance monitor local control register Bn (PERFMON_PMLCB8) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_1098                     | Performance monitor counter n (PERFMON_PMC8)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |

## **PERFMON** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|-----------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_10A0                     | Performance monitor local control register An (PERFMON_PMLCA9)  | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_10A4                     | Performance monitor local control register Bn (PERFMON_PMLCB9)  | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_10A8                     | Performance monitor counter n (PERFMON_PMC9)                    | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_10B0                     | Performance monitor local control register An (PERFMON_PMLCA10) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_10B4                     | Performance monitor local control register Bn (PERFMON_PMLCB10) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_10B8                     | Performance monitor counter n (PERFMON_PMC10)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_10C0                     | Performance monitor local control register An (PERFMON_PMLCA11) | 32                 | R/W    | 0000_0000h  | 19.3.6/1493      |
| E_10C4                     | Performance monitor local control register Bn (PERFMON_PMLCB11) | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |
| E_10C8                     | Performance monitor counter n (PERFMON_PMC11)                   | 32                 | R/W    | 0000_0000h  | 19.3.8/1495      |
| E_10D4                     | Performance monitor local control register Bn (PERFMON_PMLCB)   | 32                 | R/W    | 0000_0000h  | 19.3.7/1494      |

# 19.3.1 Performance monitor global control register (PERFMON\_PMGC0)

The performance monitor global control register (PMGC0), shown in the figure below, is a 32-bit register used to control all PMCs.



#### PERFMON\_PMGC0 field descriptions

| Description                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Freeze all counters.                                                                                                                                                                |
| 0 PMCs are incremented (if permitted by other PMGC0/PMLC bits).                                                                                                                     |
| 1 PMCs are not incremented. Set by hardware when an interrupt is signalled and FCECE =1.                                                                                            |
| Performance monitor interrupt enable. Interrupts are caused by PMC overflows.                                                                                                       |
| 0 Interrupts are disabled.                                                                                                                                                          |
| 1 Interrupts are enabled and occur when an enabled condition or event occurs.                                                                                                       |
| Freeze counters on enabled condition or event. An enabled condition or event is defined as:                                                                                         |
| The msb = 1 in PMCn and PMLCAn[CE] = 1.                                                                                                                                             |
| The use of the trigger and freeze counter conditions depends on the enabled condition.                                                                                              |
| 0 PMCs can be incremented (if permitted by other control bits).                                                                                                                     |
| 1 PMCs can be incremented (if permitted by other control bits) only until an enabled condition or event occurs, at which time PMGC0[FAC] is set. It is up to software to clear FAC. |
| This field is reserved. Reserved                                                                                                                                                    |
|                                                                                                                                                                                     |

# 19.3.2 Performance monitor local control register A0 (PERFMON PMLCA0)

The performance monitor local control registers (PMLCA n and PMLCB n) are used to control the operation of the PMCs. The performance monitor local control A and B registers are paired 32-bit control registers that are associated with an individual counter to specify how the counter is used and what event is monitored on that counter.

Address: E\_1000h base + 10h offset = E\_1010h



#### PERFMON\_PMLCA0 field descriptions

| Field   | Description                           |
|---------|---------------------------------------|
| 0<br>FC | Freeze counter. Basic counter enable. |

#### **PERFMON Memory Map/Register Definition**

### PERFMON\_PMLCA0 field descriptions (continued)

| Field     | Description                                                                                                                                                               |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | The PMCs are enabled and incremented (if permitted by other SPM control bits).                                                                                            |
|           | 1 The PMCs are disabled-they do not increment.                                                                                                                            |
| 1–4       | This field is reserved. Reserved                                                                                                                                          |
| 5<br>CE   | Condition enable. Controls counter overflow condition. Should be cleared when PMC0 is used as a trigger or is selected for chaining.                                      |
|           | <ul> <li>Overflow conditions for PMC0 cannot occur (PMC0 cannot cause interrupts or freeze counters)</li> <li>Overflow conditions occur when PMC0[msb] is set.</li> </ul> |
| 6–31<br>- | This field is reserved. Reserved                                                                                                                                          |

# 19.3.3 Performance monitor local control register B0 (PERFMON\_PMLCB0)

The performance monitor local control registers (PMLCA n and PMLCB n) are used to control the operation of the PMCs. The performance monitor local control A and B registers are paired 32-bit control registers that are associated with an individual counter to specify how the counter is used and what event is monitored on that counter.





Field Description

0-1 This field is reserved.
- Reserved

### PERFMON\_PMLCB0 field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                   |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2–5<br>TRIGONSEL     | gger-on select. The number of the counter that starts event counting. When the specified counter's tlGONCNTL event overflows, the current counter begins counting. No triggering occurs if the value is lf-referential, that is, when set to the current counter number.      |  |  |
| 6–7                  | This field is reserved. Reserved                                                                                                                                                                                                                                              |  |  |
| 8–11<br>TRIGOFFSEL   | Trigger-off select. The number of the counter that stops event counting. When the specified counter's TRIGONCNTL event overflows, the current counter stops counting. No triggering occurs if the value is self-referential, that is, when set to the current counter number. |  |  |
| 12–13<br>TRIGONCNTL  | Trigger-on control. Indicates the condition under which triggering to start counting occurs  O Trigger off (no triggering to start)  Trigger on change  Trigger on overflow  Reserved                                                                                         |  |  |
| 14–15<br>TRIGOFFCNTL | Trigger-off control. Indicates the condition under which triggering to stop occurs  O Trigger off (no triggering to stop)  Trigger on change  Trigger on overflow  Reserved                                                                                                   |  |  |
| 16–31<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                              |  |  |

# 19.3.4 Performance monitor counter 0 lower (PERFMON\_PMC0\_upper)

PMC0-PMC11 are used to count events selected by the performance monitor local control registers. PMC0\_upper, shown in the figure below, is one of two 32-bit registers that form a 64-bit counter designated to count clock cycles. PMC0 upper represents the upper 32 bits of counter 0, and PMC0 lower represents the lower 32 bits.

#### NOTE

Because accessing a PMC manually has priority over incrementing it due to event counting, writing a PMC while it is counting may affect the count. Likewise, writing a performance monitor control register while its target counter is counting may also affect the count.

Address: E\_1000h base + 18h offset = E\_1018h



#### **PERFMON Memory Map/Register Definition**

#### PERFMON\_PMC0\_upper field descriptions

| Field | Description                                                                                     |
|-------|-------------------------------------------------------------------------------------------------|
|       | Bits 0-31 of PMC0 event count. (See Performance monitor counter 0 upper (PERFMON_PMC0_lower) .) |
| PMC0  | Counts only clock cycles                                                                        |

# 19.3.5 Performance monitor counter 0 upper (PERFMON\_PMC0\_lower)

PMC0-PMC11 are used to count events selected by the performance monitor local control registers. PMC0\_lower, shown in the figure below, is one of two 32-bit registers that form a 64-bit counter designated to count clock cycles. PMC0 upper represents the upper 32 bits of counter 0, and PMC0 lower represents the lower 32 bits.

#### NOTE

Because accessing a PMC manually has priority over incrementing it due to event counting, writing a PMC while it is counting may affect the count. Likewise, writing a performance monitor control register while its target counter is counting may also affect the count.





## PERFMON\_PMC0\_lower field descriptions

| Field | Description                                                                                      |
|-------|--------------------------------------------------------------------------------------------------|
|       | Bits 32-63 of PMC0 event count. (See Performance monitor counter 0 lower (PERFMON_PMC0_upper) .) |
| PMC0  | Counts only clock cycles                                                                         |

# 19.3.6 Performance monitor local control register An (PERFMON\_PMLCAn)

The performance monitor local control registers (PMLCA n and PMLCB n) are used to control the operation of the PMCs. The performance monitor local control A and B registers are paired 32-bit control registers that are associated with an individual counter to specify how the counter is used and what event is monitored on that counter.

Address: E\_1000h base + 20h offset + (16d × i), where i=0d to 10d



## PERFMON\_PMLCAn field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                      |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>FC        | Freeze counter  0 The PMCs are incremented (if permitted by other PMC control bits).                                                                                                                                                                                                                             |
|                | 1 The PMCs are not incremented (if permitted by other PMC control bits).                                                                                                                                                                                                                                         |
| 1–4            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                 |
| 5<br>CE        | Condition enable  O Overflow conditions for PMCn cannot occur (PMCn cannot cause interrupts or freeze counters).  Should be cleared when PMCn is used as a trigger or is selected for chaining.                                                                                                                  |
|                | Overflow conditions occur when PMCn[msb] is set.                                                                                                                                                                                                                                                                 |
| 6–8            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                 |
| 9–15           | Event selector. Up to 128 events selectable.                                                                                                                                                                                                                                                                     |
| EVENT          | Note that with counter-specific events, an offset of 64 must be used when programming the field, because counter-specific events occupy the bottom 64 values of the 7-bit event field where events are numbered. For example, to specify counter-specific event 0, the event field must be programmed to 64.     |
|                | See Table 19-44 for definition of events.                                                                                                                                                                                                                                                                        |
| 16–20<br>BSIZE | Burst size. Fewest event occurrences that constitute a burst, that is, a rapid sequence of events followed by a relatively long pause. A value less than two implies regular event counting. Any non-threshold, regular event may be counted in a bursty fashion. See Burstiness counting, for more information. |
| 21–25<br>BGRAN | Burst granularity. The maximum number of clock cycles between events that are considered part of a single burst. See Burstiness counting .                                                                                                                                                                       |

### PERFMON\_PMLCAn field descriptions (continued)

| Field          | Description                                                                                                                                                      |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 26–31<br>BDIST | Burst distance (used with TBMULT). The number of clock cycles between bursts. Must be set to a value greater than BSIZE for proper burstiness counting behavior. |  |  |  |
|                | 00_0000 Regular counting                                                                                                                                         |  |  |  |

# 19.3.7 Performance monitor local control register Bn (PERFMON\_PMLCBn)

The performance monitor local control registers (PMLCA n and PMLCB n) are used to control the operation of the PMCs. The performance monitor local control A and B registers are paired 32-bit control registers that are associated with an individual counter to specify how the counter is used and what event is monitored on that counter.





#### PERFMON PMLCBn field descriptions

| Field              | Description                                                                                                                                                                                                                                                            |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1                | This field is reserved. Reserved                                                                                                                                                                                                                                       |
| 2–5<br>TRIGONSEL   | Trigger-on select. Set this field equal to the number of the counter that should trigger event counting to start. When the specified counter's TRIGONCNTL event overflows, the current counter begins counting. No triggering occurs when TRIGONSEL = current counter. |
| 6–7<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                       |
| 8–11<br>TRIGOFFSEL | Trigger-off select. Set this field equal to the number of the counter that should trigger event counting to stop. When the specified counter's TRIGONCNTL event overflows, the current counter stops counting. No triggering occurs when TRIGOFFSEL = current counter. |

## PERFMON\_PMLCBn field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 12–13<br>TRIGONCNTL  | Trigger-on control. Indicates the condition under which triggering to start counting occurs                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                      | 00 Trigger off (no triggering to start)                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                      | 01 Trigger on change                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                      | 10 Trigger on overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                      | 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 14–15<br>TRIGOFFCNTL | Trigger-off control. Indicates the condition under which triggering to stop occurs                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                      | 00 Trigger off (no triggering to stop)                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                      | 01 Trigger on change                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                      | 10 Trigger on overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                      | 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 16–20<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 21–23<br>TBMULT      | Threshold and burstiness multiplier. Threshold events are counted when the event duration exceeds a specified threshold value. The threshold is scaled based on the TBMULT settings. TBMULT is not used to scale the threshold value for quantity threshold events. The burst distance for burstiness counting is also scaled using the TBMULT settings. For all events that scale the threshold, the threshold field is multiplied by the factors shown below (ranging from 1 to 128). |  |  |  |
|                      | 000 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                      | 001 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                      | 010 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                      | 011 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                      | 100 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                      | 101 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                      | 110 64<br>111 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 04.05                | 111 112                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| 24–25<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 26–31<br>THRESHOLD   | Threshold. Only events whose (number of) occurrences exceed this value are counted. By varying the threshold value, software can characterize the events subject to the threshold. For example, if PMC2 counts eTSEC BD read latencies for which the duration exceeds the threshold, software can obtain the distribution of eTSEC BD read latencies for a given program by monitoring the program using various threshold values.                                                      |  |  |  |

## 19.3.8 Performance monitor counter n (PERFMON\_PMCn)

PMC0-PMC11 are used to count events selected by the performance monitor local control registers. PMC1-PMC11, shown in the figure below, are 32-bit counters that can monitor 64 unique events in addition to the 64 reference events that can be counted on all of these registers.

#### NOTE

Because accessing a PMC manually has priority over incrementing it due to event counting, writing a PMC while it is

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **Functional description**

counting may affect the count. Likewise, writing a performance monitor control register while its target counter is counting may also affect the count.

Address: E\_1000h base + 28h offset + (16d × i), where i=0d to 10d



### PERFMON PMCn field descriptions

| Field        | Description                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------|
| 0–31<br>PMCn | Event count. An overflow is indicated when the msb = 1. Manually setting the msb can cause an immediate interrupt. |

# 19.4 Functional description

This section describes the use of some features of the performance monitor.

## 19.4.1 Performance monitor interrupt

PMCs can generate an interrupt on an overflow when the msb of a counter changes from 0 to 1.

For the interrupt to be signalled, the condition enable bit (PMLCAn[CE]) and performance monitor interrupt enable bit (PMGC0[PMIE]) must be set. When an interrupt is signalled and the freeze-counters-on-enabled-condition-or-event bit (PMGC0[FCECE]) is set, PMGC0[FAC] is set by hardware and all of the registers are frozen. Software can clear the interrupt condition by resetting the performance monitor and clearing the most significant bit of the counter that generated the overflow.

# 19.4.2 Event counting

Using the control registers described in PERFMON Memory Map/Register Definition, the twelve PMCs can count the occurrences of specific events.

The 64-bit PMC0 is designated to count only clock cycles. However, to provide flexibility, a total of 64 reference events can be counted on any of the 32-bit PMCs (PMC1-PMC11). Additionally, up to 64 unique events can be counted on each 32-bit counter.

The performance monitor must be reset before event counting sequences. The performance monitor can be reset by first freezing one or more counters and then clearing the freeze condition to allow the counters to count according to the settings in the performance monitor registers. Counters can be frozen individually by setting PMLCAn[FC] bits, or simultaneously by setting PMGC0[FAC]. Simply clearing these freeze bits will then allow the performance monitor to begin counting based on the register settings.

Note that using PMLCAn[FC] to reset the performance monitor resets only the specified counter. Performance monitor registers can be configured through reads or writes while the counters are frozen as long as freeze bits are not cleared by the register accesses.

### 19.4.3 Threshold events

The threshold feature allows characterization of events that can take a variable number of clock cycles to occur.

Threshold events are counted only if the latency is greater than the threshold value specified in PMLCB*n*[THRESHOLD]. There are two types of threshold events.

The first type of threshold events are duration threshold events. For duration threshold event sequences, the PMC increments only when the duration of the event is equal to or greater than the threshold value. The threshold value is scaled by a multiple specified in PMLCBn[TBMULT].

A duration threshold event requires two signals: The first indicates when a threshold event sequence begins, and the second indicates when it ends. An internal counter determines when the threshold count is exceeded and when the PMC can increment. This internal counter decrements during a threshold event sequence until it reaches the value of one. A new sequence cannot begin until the current one completes. Additional threshold start signals are ignored during a sequence until a threshold stop signal occurs. If both a start and stop signal are asserted during the same cycle in a current sequence, the stop terminates the current sequence and the start signals the beginning of a new one. However, if both signals are asserted during the same cycle while not in a current event sequence, both signals are ignored. Figure 19-44 is a timing diagram for duration threshold event counting.

An illegal condition exists if the threshold value obtained from PMLCBn[THRESHOLD] and PMLCBn[TBMULT] is less than two. Under these conditions the intent of threshold counting is ambiguous.





Figure 19-44. Duration threshold event sequence timing diagram

The second type of threshold event is the quantity threshold event. For these types of threshold event sequences the performance monitor counter is only incremented when the specified threshold event exceeds the threshold value. These events do not use the multiplier register field (PMLCBn[TBMULT]) like the duration threshold events. This type of threshold event is generally used to monitor the usage of buffers and queues. For example, the usage of a specific queue could be characterized by measuring the amount of time the queue is completely full or partially full. For this example the threshold field would be used to specify how many entries are required to be valid in the queue for that event to be counted.

## 19.4.4 Chaining

By configuring one counter to increment each time another counter overflows, several counters can be chained together to provide event counts larger than 32 bits.

Each counter in a chain adds 32 bits to the maximum count. The register chaining sequence is not arbitrary and is specified indirectly by selecting the register overflow event to be counted. Selecting an event has the effect of selecting a source register because all available chaining events, as shown in Table 19-44, are dedicated to specific registers.

Note that the chaining overflow event occurs when the counter reaches its maximum value and wraps, not when the register's msb is set. For this overflow to occur, PMLCAn[CE] should be cleared to avoid signalling an interrupt when the counter's most significant bit is set. Note that several cycles may be required for the chained counters to reflect the true count because of the internal delay between when an overflow occurs and a counter increments.

## 19.4.5 Triggering

Triggering allows one counter to start or stop counting on the change of another counter or on the overflow of another counter.

More specifically, if PMC1 is set to start or stop counting as a result of a change or overflow in counter PMC2, then counter PMC2 must be identified in the local control register of counter PMC1. This is done by appropriately setting the trigger-on select bit or trigger-off select bit (PMLCB1[TRIGOFFSEL] or PMLCB1[TRIGONSEL]). Additionally, the condition that triggers the counter must be selected by configuring the corresponding control bits (PMLCB1[TRIGONCNTL] or PMLCB1[TRIGOFFCNTL]). Assuming the counter is enabled by other control register settings, the counter increments (or freezes) when its specified event occurs after the trigger-on (or off) condition occurs.

When trigger on and trigger off are both selected, the trigger-off condition is ignored until the trigger-on condition has occurred. Furthermore, when a trigger-off condition occurs, the counter state is preserved; it is not restarted by subsequent trigger-on conditions.

Triggering is disabled when the counter's trigger-select bits specify itself as the trigger source. Similarly, triggering is disabled when the trigger control bits are cleared.

## 19.4.6 Burstiness counting

The burstiness counting feature makes it easier to characterize events that occur in rapid succession followed by a relatively long pause.

As shown in the table below, event bursts are defined by size, granularity, and distance.

Table 19-43. Burst definition

| Parameter | Description                                       | RegisterField  |
|-----------|---------------------------------------------------|----------------|
| Size      | The minimum number of events constituting a burst | PMLCAn [BSIZE] |

Table 19-43. Burst definition (continued)

| Parameter   | Description                                                                     | RegisterField                   |
|-------------|---------------------------------------------------------------------------------|---------------------------------|
| Granularity | The maximum time between individual events counted as members of the same burst | PMLCAn [BGRAN]                  |
| Distance    | The minimum time between bursts                                                 | PMLCAn [BDIST] x PMLCBn[TBMULT] |

The figure below shows the relationships between size, granularity, and distance. Burstiness counting can be performed for all events except threshold events.



Figure 19-45. Burst size, distance, granularity, and burstiness counting

The burstiness size field (PMLCAn[BSIZE]) specifies the minimum number of event occurrences that constitute a burst. A burst is identified when the number of event occurrences equals or exceeds PMLCAn[BSIZE]. Furthermore, these individual event occurrences must be separated by no more clock cycles than the value in the burstiness granularity field (PMLCAn[BGRAN]). Note that, although a burst is identified when the minimum number of events occurs, it is not counted until the burst sequence has ended. A burst sequence ends when the specified burstiness granularity is exceeded, at which point the last valid event has occurred for that sequence.

PMLCAn[BGRAN] specifies the maximum number of cycles between individual events for them to qualify as members of the same burst sequence.

The burstiness distance field (PMLCAn[BDIST]) and threshold/burstiness multiplier field (PMLCBn[TBMULT]) specify the acceptable number of cycles between the end of a burst sequence and the beginning of a new sequence for a group of event occurrences to be counted as an individual burst. The product of the burstiness distance field and the threshold/burstiness multiplier field determine the burstiness distance value used to determine when another burst sequence can begin. Note that the burst distance count begins when a new burst sequence ends and the PMC is incremented. No new burst sequence may begin until the burst distance count has reached zero. After the burst distance count reaches zero, it holds the zero value indicating that a new burst sequence can be counted. The burst distance count begins again when a new burst sequence is identified and counted.

Burstiness counting is disabled when the definition of a burst is ambiguous, that is, when the burst size field is less than two, or the burst distance is zero. When burstiness counting is disabled, regular counting is allowed.

Figure 19-45 shows that the burst distance is measured from the end of one burst sequence and that a new burst sequence may not begin until the burst distance count expires.

Three internal counters track the different values required for burstiness counting.

- Burstiness size is monitored by a counter. It is loaded with the value specified in the local control register when the burst granularity counter and the burst distance counters reach zero, and no new event is occurring. It always decrements when the following conditions occur: its value is not already zero, an event occurs, and the burst distance count equals zero.
- Burstiness granularity is monitored by a counter that is loaded with the specified value in the local control register on the rising edge of an event occurrence whenever the burst distance count equals zero. The granularity counter is decremented (if it has not already reached zero) when an event is not occurring and burst distance count equals zero.
- Burstiness distance is measured by a counter that is loaded with the product of PMLCBn[BDIST] and PMLCBn[TBMULT] when a burst sequence has been identified and counted. This counter is decremented when burstiness counting is enabled (and the counter has not already reached zero).

A burst is counted at the end of a burst sequence when the three burst parameter counters are all equal to zero. Figure 19-46 shows a burstiness counting example.



Figure 19-46. Burstiness counting timing diagram

## 19.4.7 Performance monitor events

Table 19-44 lists performance monitor events specified in PMLCA1-PMLC11.

The event assignment column indicates the event's type and number, using the following formats:

- Ref:#-Reference events are shared across counters PMC1-PMC11. The number indicates the event. For example, Ref:6 means that PMC1-PMC11 share reference event 6.
- C[0-11]:#-Counter-specific events. C8 indicates an event assigned to PMC8. Thus C8:62 means PMC8 is assigned event 62 (PIC interrupt wait cycles).

Counter events not specified in Table 19-44 are reserved.

#### **NOTE**

- Some functional blocks may operate at a frequency other than that of the performance monitor. In these cases, the count represented by the performance monitor counters may be inaccurate.
- Some functional blocks are running at half of CCB clock and their events are counted twice in performance monitor.

Other than performance monitor events, Table 19-44 also lists the clock information for each of the functional block.

Table 19-44. Performance monitor events

| Event Counted                                                | Number              | Description of Event Counted                                                                                                                                                                                                                                                                                                                            |  |  |
|--------------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| General Events                                               |                     |                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Nothing                                                      | Ref:0               | Register counter holds current value                                                                                                                                                                                                                                                                                                                    |  |  |
| System cycles                                                | C0 and<br>Ref:63    | CCB (platform) clock cycles                                                                                                                                                                                                                                                                                                                             |  |  |
| DDR Memory Controller Events                                 | -!                  |                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Clock information-Async or CCB Clock (Sync Moc               | le)                 |                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Cycles a read is returning data from DRAM                    | Ref:19              | Each data beat returned to the memory controller on the DRAM interface                                                                                                                                                                                                                                                                                  |  |  |
| Cycles a read or write transfers data from (or to) DRAM      | Ref:27              | Each data beat transferred to or from the DRAM                                                                                                                                                                                                                                                                                                          |  |  |
| Pipelined read misses in the row open table                  | C1:121              | Row open table read misses issued while a read is outstanding                                                                                                                                                                                                                                                                                           |  |  |
| Pipelined read or write misses in the row open table         | C2:64               | Row open table read or write misses issued while a read or write is outstanding                                                                                                                                                                                                                                                                         |  |  |
| Non-pipelined read misses in the row open table              | C3:124              | Row open table read misses issued when no reads are outstanding                                                                                                                                                                                                                                                                                         |  |  |
| Non-pipelined read or write misses in the row open table     | C4:64               | Row open table read or write misses issued when no reads or writes are outstanding                                                                                                                                                                                                                                                                      |  |  |
| Pipelined read hits in the row open table                    | C5:120              | Row open table read hits issued when a read is outstanding                                                                                                                                                                                                                                                                                              |  |  |
| Pipelined read or write hits in the row open table           | C6:64               | Row open table read or write hits issued when a read or write is outstanding                                                                                                                                                                                                                                                                            |  |  |
| Non-pipelined read hits in the row open table                | C7:121              | Row open table read hits issued when no reads are outstanding                                                                                                                                                                                                                                                                                           |  |  |
| Non-pipelined read or write hits in the row open table       | C8:64               | Row open table read or write hits issued when no reads or writes are outstanding                                                                                                                                                                                                                                                                        |  |  |
| Forced page closings not caused by a refresh                 | C1:64               | Precharges issued to the DRAM for any reason except refresh. The possibilities are as follows:                                                                                                                                                                                                                                                          |  |  |
|                                                              |                     | <ul> <li>A new transaction must be issued to an already active bank and sub-bank that has a different row open.</li> <li>A new transaction must be issued, but the row open table is full and there is no bank/sub-bank match between the current transaction and the row open table.</li> <li>The BSTOPRE interval expired for an open row.</li> </ul> |  |  |
| Row open table misses                                        | C2:65 and<br>C11:66 | Transactions that miss in the row open table                                                                                                                                                                                                                                                                                                            |  |  |
| Row open table hits                                          | C3:64 and<br>C10:68 | Transaction that hit in the row open table                                                                                                                                                                                                                                                                                                              |  |  |
| Force page closings                                          | C4:65               | Forced page closings including those due to refreshes                                                                                                                                                                                                                                                                                                   |  |  |
| Read-modify-write transactions due to ECC                    | C5:64               | If ECC is enabled and a transaction requires byte enables, a read-modify-write sequence is issued on the DRAM interface.                                                                                                                                                                                                                                |  |  |
| Forced page closings due to collision with bank and sub-bank | C9:64               | Increments if a new transaction must be issued to an active bank and sub-bank that has a different row open                                                                                                                                                                                                                                             |  |  |

Table 19-44. Performance monitor events (continued)

| Event Counted                                                                        | Number              | Description of Event Counted                          |
|--------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------|
| Reads or writes from core 0-1                                                        | Ref:13              | -                                                     |
| Reads or writes from eTSEC 1-3                                                       | C3:65               | -                                                     |
| Reads or writes from high speed interfaces (PCI Express 1-2)                         | C4:67               | -                                                     |
| Reads or writes from DMA                                                             | C5:66               | -                                                     |
| Reads or writes from Security                                                        | C6:69               | -                                                     |
| Row open table hits for reads or writes from core 0-1                                | Ref:14              | -                                                     |
| Row open table hits for reads or writes from eTSEC 1-4                               | C6:65               | -                                                     |
| Row open table hits for reads or writes from high speed interfaces (PCI Express 1-2) | C7:65               | -                                                     |
| Row open table hits for reads or writes from DMA                                     | C8:66               | -                                                     |
| Row open table hits for reads or writes from Security                                | C7:68 and<br>C10:65 | -                                                     |
| DMA Controller Events                                                                |                     |                                                       |
| Clock information- (CCB Clock) / 2                                                   |                     |                                                       |
| Channel 0 read request                                                               | C1:66               | DMA channel 0 read request active in the system       |
| Channel 1 read request                                                               | C2:69               | DMA channel 1 read request active in the system       |
| Channel 2 read request                                                               | C3:68               | DMA channel 2 read request active in the system       |
| Channel 3 read request                                                               | C4:70               | DMA channel 3 read request active in the system       |
| Channel 0 write request                                                              | C1:67               | DMA channel 0 write request active in the system      |
| Channel 1 write request                                                              | C2:70               | DMA channel 1 write request active in the system      |
| Channel 2 write request                                                              | C3:69               | DMA channel 2 write request active in the system      |
| Channel 3 write request                                                              | C4:71               | DMA channel 3 write request active in the system      |
| Channel 0 descriptor request                                                         | C5:105              | DMA channel 0 descriptor request active in the system |
| Channel 1 descriptor request                                                         | C6:108              | DMA channel 1 descriptor request active in the system |
| Channel 2 descriptor request                                                         | C7:105              | DMA channel 2 descriptor request active in the system |
| Channel 3 descriptor request                                                         | C8:105              | DMA channel 3 descriptor request active in the system |
| Channel 0 read DW or less                                                            | C1:68 and<br>C5:117 | DMA channel 0 read double word valid                  |
| Channel 1 read DW or less                                                            | C2:71 and<br>C6:122 | DMA channel 1 read double word valid                  |
| Channel 2 read DW or less                                                            | C3:70 and<br>C7:118 | DMA channel 2 read double word valid                  |
| Channel 3 read DW or less                                                            | C4:72 and<br>C8:116 | DMA channel 3 read double word valid                  |
| Channel 0 write DW or less                                                           | C1:69               | DMA channel 0 write double word valid                 |
| Channel 1 write DW or less                                                           | C2:72               | DMA channel 1 write double word valid                 |
| Channel 2 write DW or less                                                           | C3:71               | DMA channel 2 write double word valid                 |
| Channel 3 write DW or less                                                           | C4:73               | DMA channel 3 write double word valid                 |

Table 19-44. Performance monitor events (continued)

| Event Counted                                              | Number  | Description of Event Counted                                       |
|------------------------------------------------------------|---------|--------------------------------------------------------------------|
| e500 Coherency Module (ECM) Events                         | Į       | ·                                                                  |
| Clock information-CCB Clock                                |         |                                                                    |
| ECM request wait core 0                                    | C8:77   | Asserted for every cycle core 0 request occurs                     |
| ECM request wait core 1                                    | C11:98  | Asserted for every cycle core 1 request occurs                     |
| ECM request wait I <sup>2</sup> C/Security/Test Port/USB   | C7:77   | Asserted for every cycle I2C/Security/Test Port/USB request occurs |
| ECM request wait PEX1-2/DMA                                | C5:80   | Asserted for every cycle PEX1-2/DMA request occurs                 |
| ECM request wait eTSEC1-3                                  | C6:80   | Asserted for every cycle eTSEC1-3 request occurs                   |
| ECM request wait SAP/USB/eSDHC /QE                         | C4:84   | Asserted for every cycle SAP/USB/eSDHC/QE request occurs           |
| ECM dispatch                                               | Ref:15  | ECM dispatch (includes address only's)                             |
|                                                            |         | Note: all ECM dispatch events are for committed dispatches         |
| ECM dispatch from core 0                                   | C1:80   | ECM dispatch from core 0 (includes address only's)                 |
| ECM dispatch from core 1                                   | C10:95  | ECM dispatch from core 1 (includes address only's)                 |
| ECM dispatch from USB /QE                                  | C10:87  | ECM dispatch from USB /QE                                          |
| ECM dispatch from eTSEC1                                   | C4:85   | -                                                                  |
| ECM dispatch from eTSEC2                                   | C8:80   | -                                                                  |
| ECM dispatch from eTSEC3                                   | C9:80   | -                                                                  |
| ECM dispatch from PEX1                                     | C7:78   | -                                                                  |
| ECM dispatch from PEX2                                     | C10:98  | -                                                                  |
| ECM dispatch from DMA                                      | C9:82   | -                                                                  |
| ECM dispatch from Security                                 | C10:100 | -                                                                  |
| ECM dispatch from USB Host                                 | C10:66  | -                                                                  |
| ECM dispatch from USB Dual Role                            | C9:68   | -                                                                  |
| ECM dispatch from other                                    | C6:82   | -                                                                  |
| ECM dispatch to DDR                                        | C7:79   | ECM dispatch to DDR (excludes address only)                        |
| ECM dispatch to L2                                         | C10:102 | -                                                                  |
| ECM dispatch to SRAM                                       | C8:79   | -                                                                  |
| ECM dispatch to LBC                                        | C9:83   | -                                                                  |
| ECM dispatch to PEX1                                       | C2:85   | -                                                                  |
| ECM dispatch to PEX2                                       | C1:81   | -                                                                  |
| ECM dispatch to CCSR                                       | C9:87   | -                                                                  |
| ECM dispatch write                                         | C7:81   | -                                                                  |
| ECM dispatch write allocate                                | C1:82   | -                                                                  |
| ECM dispatch read                                          | C2:86   | -                                                                  |
| ECM dispatch read atomic                                   | C3:86   | -                                                                  |
| ECM data bus grant DDR                                     | C1:83   | -                                                                  |
| ECM data bus grant I <sup>2</sup> C/Security/Test Port/USB | C3:87   | -                                                                  |
| ECM data bus grant PEX1-2/DMA                              | C4:89   | -                                                                  |
| ECM data bus grant LBC                                     | Ref:16  | -                                                                  |
| ECM data bus grant eTSEC1-3                                | Ref:17  | -                                                                  |

Table 19-44. Performance monitor events (continued)

| Event Counted                                                 | Number | Description of Event Counted                                                                                |
|---------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------|
| ECM data bus grant SAP/USB/eSDHC /QE                          | Ref:18 | -                                                                                                           |
| ECM global data bus beat                                      | C5:86  | -                                                                                                           |
| ECM e500 direct read bus beat                                 | C11:95 | -                                                                                                           |
| ECM e500 direct read bus beat forwarded                       | C7:84  | ECM direct read bus beat forwarded directly to e500 R1 data bus                                             |
| ECM cancel                                                    | C8:83  | -                                                                                                           |
| Boot Sequencer/Security/USB requests                          | C1:119 | Number of requests (total)                                                                                  |
| Boot Sequencer/Security/USB read requests                     | C2:76  | Number of read requests                                                                                     |
| Boot Sequencer/Security/USB data beats                        | C3:75  | Number of data beats (total)                                                                                |
| Boot Sequencer/Security/USB read data beats                   | C4:79  | Number of read data beats                                                                                   |
| SAP/USB/eSDHC /QE requests                                    | C1:99  | Number of requests (total)                                                                                  |
| SAP/USB/eSDHC /QE read requests                               | C10:78 | Number of read requests                                                                                     |
| SAP/USB/eSDHC /QE data beats                                  | C11:76 | Number of data beats (total)                                                                                |
| SAP/USB/eSDHC /QE read data beats                             | C5:96  | Number of read data beats                                                                                   |
| Mag2Cu (SAP/USB/eSDHC /QE) magenta request less than 32 bytes | C3:101 | Number of magenta requests less than 32 bytes                                                               |
| Interrupt Controller (PIC) Events                             |        |                                                                                                             |
| Clock information-CCB Clock                                   |        |                                                                                                             |
| PIC total interrupt count                                     | Ref:26 | Total number of interrupts serviced                                                                         |
| PIC interrupt wait cycles                                     | C8:126 | Counts cycles when an interrupt waits to be acknowledge                                                     |
| PIC interrupt service cycles                                  | C2:83  | Number of cycles there is an interrupt currently being serviced.                                            |
| PIC interrupt select 0 (Duration threshold)                   | C1:120 | THRESHOLD: select 0-3: interrupt count over threshold.                                                      |
| PIC interrupt select 1 (Duration threshold)                   | C3:123 | (Note: only unmasked, nonzero priority requests are acknowledged). The four interrupts are selected through |
| PIC interrupt select 2 (Duration threshold)                   | C5:119 | register pairs, PM0MRn-PM3MRn. See Performance monitor                                                      |
| PIC interrupt select 3 (Duration threshold)                   | C6:124 | mask registers (PMMRs).                                                                                     |
| eTSEC 1 Events                                                |        |                                                                                                             |
| Clock information-(CCB Clock) / 2                             |        |                                                                                                             |
| DMA write data beats                                          | C3:109 | DMA write data beats                                                                                        |
| DMA read data beats                                           | C4:110 | DMA read data beats                                                                                         |
| DMA Write Request                                             | C5:106 | DMA Write Request                                                                                           |
| DMA Read Request                                              | C6:109 | DMA Read Request                                                                                            |
| Number of dropped frames                                      | C9:88  | Number of dropped frames                                                                                    |
| TxBD read lifetime (Duration Threshold)                       | Ref:34 | TxBD read lifetime                                                                                          |
| RxBD read lifetime (Duration Threshold)                       | Ref:38 | RxBD read lifetime                                                                                          |
| TxBD write lifetime (Duration Threshold)                      | Ref:42 | TxBD write lifetime                                                                                         |
| RxBD write lifetime (Duration Threshold)                      | Ref:46 | RxBD write lifetime                                                                                         |
| Read data lifetime (Duration Threshold)                       | Ref:50 | Read data lifetime                                                                                          |
| Rx IP packets checked for checksum                            | C9:92  | Rx IP packets checked for checksum                                                                          |
| <u> </u>                                                      | C1:105 | TX IP packet with checksum                                                                                  |

Table 19-44. Performance monitor events (continued)

| Event Counted                                       | Number | Description of Event Counted                 |
|-----------------------------------------------------|--------|----------------------------------------------|
| TX TCP/UDP packet with checksum                     | C2:113 | TX TCP/UDP packet with checksum              |
| TCP/UDP packets checked for c.s.                    | C3:114 | TCP/UDP packets checked for c.s.             |
| IP or TCP/UDP Rx checksum error                     | C4:115 | IP or TCP/UDP Rx checksum error              |
| Number of rejected frames by filer                  | C5:111 | Number of rejected frames by filer           |
| Number of rejected frames due to filer error        | C6:114 | Number of rejected frames due to filer error |
| Number of cycles Rx FIFO > 1/4 full                 | C5:110 | Number of cycles Rx FIFO > 1/4 full          |
| Number of cycles Rx FIFO > 1/2 full                 | C6:113 | Number of cycles Rx FIFO > 1/2 full          |
| Number of cycles Rx FIFO > 3/4 full                 | C7:110 | Number of cycles Rx FIFO > 3/4 full          |
| Number of cycles Rx FIFO = full                     | C8:110 | Number of cycles Rx FIFO = full              |
| Number of accepted frames match                     | C9:110 | -                                            |
| Number of accepted frames to station address        | C10:80 | -                                            |
| Number of accepted unicaset frames via hash         | C11:78 | -                                            |
| Number of accepted group frames via hash            | C6:96  | -                                            |
| Number of accepted frames via exact match           | C7:100 | -                                            |
| Number of rejected frames at layer 2                | C9:111 | -                                            |
| Number of RX interrupts signalled                   | C8:94  | -                                            |
| Number of TX interrupts signalled                   | C9:112 | -                                            |
| RX data write lifetime (Duration Threshold)         | C10:81 | -                                            |
| Number of RX packets received while RX FIFO is full | C11:79 | -                                            |
| eTSEC 2 Events                                      |        |                                              |
| Clock information-(CCB Clock) / 2                   |        |                                              |
| DMA write data beats                                | C5:107 | DMA write data beats                         |
| DMA read data beats                                 | C6:110 | DMA read data beats                          |
| DMA Write Request                                   | C7:107 | DMA Write Request                            |
| DMA Read Request                                    | C8:107 | DMA Read Request                             |
| Number of dropped frames                            | C2:110 | Number of dropped frames                     |
| TxBD read lifetime (Duration Threshold)             | Ref:35 | TxBD read lifetime                           |
| RxBD read lifetime (Duration Threshold)             | Ref:39 | RxBD read lifetime                           |
| TxBD write lifetime (Duration Threshold)            | Ref:43 | TxBD write lifetime                          |
| RxBD write lifetime (Duration Threshold)            | Ref:47 | RxBD write lifetime                          |
| Read data lifetime (Duration Threshold)             | Ref:51 | Read data lifetime                           |
| Rx IP packets checked for checksum                  | C3:115 | Rx IP packets checked for checksum           |
| TX IP packet with checksum                          | C4:116 | TX IP packet with checksum                   |
| TX TCP/UDP packet with checksum                     | C5:101 | TX TCP/UDP packet with checksum              |
| TCP/UDP packets checked for c.s.                    | C6:115 | TCP/UDP packets checked for c.s.             |
| IP or TCP/UDP Rx checksum error                     | C7:111 | IP or TCP/UDP Rx checksum error              |
| Number of rejected frames by filer                  | C8:111 | Number of rejected frames by filer           |
| Number of rejected frames due to filer error        | C9:93  | Number of rejected frames due to filer error |
| Number of cycles Rx FIFO > 1/4 full                 | C7:113 | Number of cycles Rx FIFO > 1/4 full          |

Table 19-44. Performance monitor events (continued)

| Event Counted Number                                |                                                               | Description of Event Counted                 |  |  |
|-----------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|--|--|
| Number of cycles Rx FIFO > 1/2 full                 | C8:113                                                        | Number of cycles Rx FIFO > 1/2 full          |  |  |
| Number of cycles Rx FIFO > 3/4 full                 | C9:96                                                         | Number of cycles Rx FIFO > 3/4 full          |  |  |
| Number of cycles Rx FIFO = full                     | C1:108                                                        | Number of cycles Rx FIFO = full              |  |  |
| Number of accepted frames match                     | C9:113                                                        | -                                            |  |  |
| Number of accepted frames to station address        | C10:82                                                        | -                                            |  |  |
| Number of accepted unicaset frames via hash         | C11:80                                                        | -                                            |  |  |
| Number of accepted group frames via hash            | C6:97                                                         | -                                            |  |  |
| Number of accepted frames via exact match           | C7:101                                                        | -                                            |  |  |
| Number of rejected frames at layer 2                | C9:114                                                        | -                                            |  |  |
| Number of RX interrupts signalled                   | C10:83                                                        | -                                            |  |  |
| Number of TX interrupts signalled                   | C11:81                                                        | -                                            |  |  |
| RX data write lifetime (Duration Threshold)         | C8:96                                                         | -                                            |  |  |
| Number of RX packets received while RX FIFO is full | C9:115                                                        | -                                            |  |  |
| eTSEC 3 Events                                      |                                                               |                                              |  |  |
| Clock information-(CCB Clock) / 2                   |                                                               |                                              |  |  |
| DMA write data beats                                | C7:108                                                        | DMA write data beats                         |  |  |
| DMA read data beats                                 | C8:108                                                        | DMA read data beats                          |  |  |
| DMA Write Request                                   | C9:90                                                         | DMA Write Request                            |  |  |
| DMA Read Request                                    | C1:103                                                        | DMA Read Request                             |  |  |
| Number of dropped frames                            | C4:112                                                        | Number of dropped frames                     |  |  |
| TxBD read lifetime (Duration Threshold)             | Ref:36                                                        | TxBD read lifetime                           |  |  |
| RxBD read lifetime (Duration Threshold)             | Ref:40                                                        | RxBD read lifetime                           |  |  |
| TxBD write lifetime (Duration Threshold)            | Ref:44                                                        | TxBD write lifetime                          |  |  |
| RxBD write lifetime (Duration Threshold)            | Ref:48                                                        | RxBD write lifetime                          |  |  |
| Read data lifetime (Duration Threshold)             | Ref:52                                                        | Read data lifetime                           |  |  |
| Rx IP packets checked for checksum                  | C6:116                                                        | Rx IP packets checked for checksum           |  |  |
| TX IP packet with checksum                          | C7:112                                                        | TX IP packet with checksum                   |  |  |
| TX TCP/UDP packet with checksum                     | P packet with checksum C8:112 TX TCP/UDP packet with checksum |                                              |  |  |
| TCP/UDP packets checked for c.s.                    | d for c.s. C9:94 TCP/UDP packets checked for c.s.             |                                              |  |  |
| IP or TCP/UDP Rx checksum error                     | C1:106                                                        | IP or TCP/UDP Rx checksum error              |  |  |
| Number of rejected frames by filer                  | C2:114                                                        | Number of rejected frames by filer           |  |  |
| Number of rejected frames due to filer error        | C3:116                                                        | Number of rejected frames due to filer error |  |  |
| Number of cycles Rx FIFO > 1/4 full                 | C9:97                                                         | Number of cycles Rx FIFO > 1/4 full          |  |  |
| Number of cycles Rx FIFO > 1/2 full                 | C1:109                                                        | Number of cycles Rx FIFO > 1/2 full          |  |  |
| Number of cycles Rx FIFO > 3/4 full                 | C2:116                                                        | Number of cycles Rx FIFO > 3/4 full          |  |  |
| Number of cycles Rx FIFO = full                     | C3:118                                                        | Number of cycles Rx FIFO = full              |  |  |
| Number of accepted frames match                     | C9:116                                                        | -                                            |  |  |
| Number of accepted frames to station address        | C10:84                                                        | -                                            |  |  |
| Number of accepted unicaset frames via hash         | C11:82                                                        | -                                            |  |  |

Table 19-44. Performance monitor events (continued)

| Event Counted                                       | Number | Description of Event Counted                                                                                                   |  |
|-----------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------|--|
| Number of accepted group frames via hash            | C6:98  | -                                                                                                                              |  |
| Number of accepted frames via exact match           | C7:102 | -                                                                                                                              |  |
| Number of rejected frames at layer 2                | C9:117 | -                                                                                                                              |  |
| Number of RX interrupts signalled                   | C8:97  | -                                                                                                                              |  |
| Number of TX interrupts signalled                   | C9:118 | -                                                                                                                              |  |
| RX data write lifetime (Duration Threshold)         | C10:85 | -                                                                                                                              |  |
| Number of RX packets received while RX FIFO is full | C11:83 | -                                                                                                                              |  |
| PCI Express 1 to OCeaN Gasket Events                | •      |                                                                                                                                |  |
| Clock information-(CCB Clock) / 2                   |        |                                                                                                                                |  |
| Inbound PCIe read                                   | C8:119 | A single pulse to indicate an inbound PCIe read has occurred.                                                                  |  |
| Inbound PCIe write                                  | C9:101 | A single pulse to indicate an inbound PCIe write has occurred.                                                                 |  |
| Inbound PCIe data                                   | C5:124 | A level signal to indicate the amount of data transferred if any for inbound PCIe request. Active for every beat of PCIe data. |  |
| Outbound PCIe read                                  | C6:126 | A single pulse to indicate an outbound PCIe read has occurred.                                                                 |  |
| Outbound PCIe write                                 | C7:125 | A single pulse to indicate an outbound PCIe write has occurred.                                                                |  |
| Outbound PCIe data                                  | C8:124 | A level signal to indicate the amount of data transferred if are for outbound PCIe request. Active for every beat of PCIe da   |  |
| Inbound Static Queue 0 start (Duration Threshold)   | Ref:54 | Lifetime of ISQ entry 0 or 6.                                                                                                  |  |
| Outbound Static Queue 0 start (Duration Threshold)  | Ref:55 | Lifetime of OSQ entry 0.                                                                                                       |  |
| PCI Express 2 to OCeaN Gasket Events                | '      |                                                                                                                                |  |
| Clock information-(CCB Clock) / 2                   |        |                                                                                                                                |  |
| Inbound PCIe read                                   | C3:102 | A single pulse to indicate an inbound PCIe read has occurred.                                                                  |  |
| Inbound PCIe write                                  | C4:103 | A single pulse to indicate an inbound PCIe write has occurred.                                                                 |  |
| Inbound PCIe data                                   | C5:97  | A level signal to indicate the amount of data transferred if any for inbound PCIe request. Active for every beat of PCIe data. |  |
| Outbound PCIe read                                  | C1:95  | A single pulse to indicate an outbound PCIe read has occurred.                                                                 |  |
| Outbound PCIe write                                 | C2:101 | A single pulse to indicate an outbound PCIe write has occurred.                                                                |  |
| Outbound PCIe data                                  | C11:87 | A level signal to indicate the amount of data transferred if any for outbound PCIe request. Active for every beat of PCIe data |  |
| Inbound Static Queue 0 start (Duration Threshold)   | Ref:32 | Lifetime of ISQ entry 0 or 6.                                                                                                  |  |
| Outbound Static Queue 0 start (Duration Threshold)  | Ref:33 | Lifetime of OSQ entry 0.                                                                                                       |  |
| Local Bus Events                                    | •      |                                                                                                                                |  |
| Clock information-CCB Clock                         |        |                                                                                                                                |  |
| Number of correctable FCM ECC errors                | C3:121 | -                                                                                                                              |  |
| Number of uncorrectable FCM ECC errors              | C6:119 | -                                                                                                                              |  |

Table 19-44. Performance monitor events (continued)

| Event Counted                                                          | Number | Description of Event Counted                   |  |
|------------------------------------------------------------------------|--------|------------------------------------------------|--|
| Atomic reservation time-outs for ECM port                              | C6:118 | -                                              |  |
| Cycles for a read to FCM buffer RAM                                    | C7:115 | -                                              |  |
| Cycles for a write to FCM buffer RAM                                   | C8:115 | -                                              |  |
| Cycles a read is taking in GPCM                                        | C1:117 | -                                              |  |
| Cycles a read is taking in UPM                                         | C2:122 | -                                              |  |
| Cycles a write is taking in GPCM                                       | C4:120 | -                                              |  |
| Cycles a write is taking in UPM                                        | C5:114 | -                                              |  |
| L2 Cache/SRAM Events                                                   |        |                                                |  |
| Clock information-CCB Clock                                            |        |                                                |  |
| L2 clearing of locks                                                   | Ref:22 | -                                              |  |
| Core instruction accesses to L2 that hit                               | C2:123 | -                                              |  |
| Core instruction accesses to L2 that miss                              | Ref:23 | -                                              |  |
| Core data accesses to L2 that hit                                      | C4:121 | -                                              |  |
| Core data accesses to L2 that miss                                     | C5:115 | -                                              |  |
| Non-core burst write to L2 (cache external write or SRAM)              | C6:120 | -                                              |  |
| Non-core non-burst write to L2                                         | C7:116 | -                                              |  |
| Noncore write misses cache external write window and SRAM memory range | Ref:24 | -                                              |  |
| Non-core read hit in L2                                                | C1:118 | -                                              |  |
| Non-core read miss in L2                                               | Ref:25 | -                                              |  |
| L2 allocates, from any source                                          | C2:124 | -                                              |  |
| L2 retries due to full write queue                                     | C3:122 | -                                              |  |
| L2 retries due to address collision                                    | C4:122 | -                                              |  |
| L2 failed lock attempts due to full set                                | C5:116 | -                                              |  |
| L2 victimizations of valid lines                                       | C6:121 | -                                              |  |
| L2 invalidations of lines                                              | C7:117 | -                                              |  |
| Debug Events                                                           |        |                                                |  |
| Clock information-CCB Clock                                            |        |                                                |  |
| External event                                                         | C3:125 | Number of cycles trig_in pin is asserted       |  |
| Watchpoint monitor hits                                                | C2:125 | -                                              |  |
| Trace buffer hits                                                      | C1:122 | -                                              |  |
| DUART Events                                                           |        |                                                |  |
| Clock information-CCB Clock                                            |        |                                                |  |
| UART0 baud rate                                                        | C1:127 | -                                              |  |
| UART1 baud rate                                                        | C5:127 | -                                              |  |
| Chaining Events                                                        | •      |                                                |  |
| Clock information-CCB Clock                                            |        |                                                |  |
| PMC0 carry-out                                                         | Ref:1  | PMC0[0] 1-to-0 transitions.                    |  |
| PMC1 carry-out                                                         | Ref:2  | PMC1[0] 1-to-0 transitions. Reserved for PMC1. |  |

Table 19-44. Performance monitor events (continued)

| Event Counted   | Number | Description of Event Counted                     |
|-----------------|--------|--------------------------------------------------|
| PMC2 carry-out  | Ref:3  | PMC2[0] 1-to-0 transitions. Reserved for PMC2.   |
| PMC3 carry-out  | Ref:4  | PMC3[0] 1-to-0 transitions. Reserved for PMC3.   |
| PMC4 carry-out  | Ref:5  | PMC4[0] 1-to-0 transitions. Reserved for PMC4.   |
| PMC5 carry-out  | Ref:6  | PMC5[0] 1-to-0 transitions. Reserved for PMC5.   |
| PMC6 carry-out  | Ref:7  | PMC6[0] 1-to-0 transitions. Reserved for PMC6.   |
| PMC7 carry-out  | Ref:8  | PMC7[0] 1-to-0 transitions. Reserved for PMC7.   |
| PMC8 carry-out  | Ref:9  | PMC8[0] 1-to-0 transitions. Reserved for PMC8.   |
| PMC9 carry-out  | Ref:10 | PMC9[0] 1-to-0 transitions. Reserved for PMC9.   |
| PMC10 carry-out | Ref:11 | PMC10[0] 1-to-0 transitions. Reserved for PMC10. |
| PMC11 carry-out | Ref:12 | PMC11[0] 1-to-0 transitions. Reserved for PMC11. |

# 19.4.8 Performance monitor examples

The table below contains sample register settings for the four supported modes.

- Simple event performance monitoring example
- Triggering event performance monitoring example
- Threshold event performance monitoring example
- Burstiness event performance monitoring example

Table 19-45. Register settings for counting examples

| Register | Register Field | Simple Event | Triggering | Threshold | Burstiness |
|----------|----------------|--------------|------------|-----------|------------|
| PMGC0    | FAC            | 0            | 0          | 0         | 0          |
|          | PMIE           | 1            | 1          | 1         | 1          |
|          | FCECE          | 1            | 1          | 1         | 1          |
| PMLCAn   | FC             | 0            | 0          | 0         | 0          |
|          | CE             | 1            | 1          | 1         | 1          |
|          | EVENT          | 89           | 68         | 39        | 2          |
|          | BSIZE          | 0            | 0          | 0         | 5          |
|          | BGRAN          | 0            | 0          | 0         | 1          |
|          | BDIST          | 0            | 0          | 0         | 8          |
| PMLCBn   | TRIGONSEL      | 0            | 3          | 0         | 0          |
|          | TRIGOFFSEL     | 0            | 5          | 0         | 0          |
|          | TRIGONCNTL     | 0            | 1          | 0         | 0          |
|          | TRIGOFFCNTL    | 0            | 2          | 0         | 0          |
|          | TBMULT         | 0            | 0          | 0         | 0          |
|          | THRESHOLD      | 0            | 0          | 3         | 0          |

The settings in the table below are identical for all four examples.

Table 19-46. PMGC0 and PMLCAn settings

| Field        | Setting | Reason                                                               |
|--------------|---------|----------------------------------------------------------------------|
| PMGC0[FAC]   | 0       | Counters must not be frozen.                                         |
| PMGC0[PMIE]  | 1       | Performance monitor interrupts are enabled                           |
| PMGC0[FCECE] | 1       | Counters should be frozen when an interrupt is signalled.            |
| PMLCAn[FC]   | 0       | Counters cannot be frozen for counting.                              |
| PMLCAn[CE]   | 1       | Overflow condition enable is required to allow interrupt signalling. |

For simple event counting, a non-threshold event is selected in PMLCAn[EVENT] and all other features are disabled by clearing all register fields except for CE.

For the triggering example any event can be selected in PMLCAn[EVENT]. All other features are disabled by clearing these register fields except for CE to allow interrupt signalling. If PMLCBn[TRIGONSEL] is 3 and PMLCBn[TRIGOFFSEL] is 5, the counter begins and ends counting based on the conditions in counters three and five. Furthermore, if PMLCBn[TRIGONCNTL] is 1, the counter begins counting when PMC3 changes value. According to the setting in PMLCBn[TRIGOFFCNTL], the counter ends counting when PMC5 overflows. Also, although the register settings for PMC5 is not shown, PMLCAn[CE] for this counter must be cleared so that interrupt signalling is not enabled and the counter does not freeze when it overflows.

For threshold counting, a threshold event must be specified in PMLCA*n*[EVENT]. For this example, the duration threshold value is scaled by two because PMLCB*n*[TBMULT] is one. All other features are disabled by clearing the appropriate fields.

Any non-threshold event can use the burstiness feature. For burstiness counting, values for PMLCAn[BSIZE,BGRAN,BDIST] and PMLCBn[TBMULT] must be specified.

# 19.5 Initialization/application information

The performance monitor must be reset before event counting sequences.

The performance monitor must be reset before event counting sequences. The performance monitor can be reset by first freezing one or more counters and then clearing the freeze condition to allow the counters to count according to the settings in the performance monitor registers. Counters can be frozen individually by setting PMLCAn[FC] bits, or simultaneously by setting PMGC0[FAC]. Simply clearing these freeze bits will then allow the performance monitor to begin counting based on the register settings.

Note that using PMLCAn[FC] to reset the performance monitor resets only the specified counter. Performance monitor registers can be configured through reads or writes while the counters are frozen as long as freeze bits are not cleared by the register accesses.

Initialization/application information

# Chapter 20 Global Utilities

This chapter describes the global utilities of the chip. It provides signal descriptions, register descriptions, and a functional description of these utilities.

#### 20.1 Introduction

This chapter describes the global utilities of the P1021.

It provides signal descriptions, register descriptions, and a functional description of these utilities.

#### 20.2 Overview

The global utilities block controls power management, I/O device enabling, power-on-reset (POR) configuration monitoring, alternate function selection for multiplexed signals, and clock control.

### 20.3 Global utilities features

This section provides an overview of global utilities features.

## 20.3.1 Power management and block disables

The following features affect the device's overall power consumption:

- Dynamic power management mode
- Software-controlled power management (doze, nap, sleep)

#### Global utilities external signal description

- Externally controlled power management (doze, sleep)
- Static power management (I/O block disables)

## 20.3.2 Accessing current POR configuration settings

The POR configuration values of all device parameters sampled from pins at reset are available through memory-mapped registers in the global utilities block.

#### 20.3.3 Clock control

The global utilities block also selects the internal clock signal driven on CLK\_OUT.

## 20.4 Global utilities external signal description

The following subsections provide information about signals that serve as global utilities.

## 20.4.1 Signals overview

Table 20-1 summarizes the external signals used by the global utilities block.

Table 20-1. External signal summary

| Signal Name  | I/O | Description                                       | Reference                                |
|--------------|-----|---------------------------------------------------|------------------------------------------|
| ASLEEP       | 0   | Signals that the device has reached a sleep state | Sleep mode                               |
| CKSTP_IN0_B  | I   | Checkstop input 0                                 | Table 20-2                               |
| CKSTP_IN1_B  | I   | Checkstop input 1                                 | Table 20-2                               |
| CKSTP_OUT0_B | 0   | Checkstop output 0                                | Table 20-2                               |
| CKSTP_OUT1_B | 0   | Checkstop output 1                                | Table 20-2                               |
| CLK_OUT_B    | 0   | Clock out. Selected by CLKOCR values              | Clock out control register (GUTS_CLKOCR) |

# 20.4.2 Detailed signal descriptions

The table below describes signals in the global utilities block in detail.

Table 20-2. Detailed signal descriptions

| Signal      | I/O | Description                                                                                                                                                |                                                                                                                                                                                                                                                                                 |  |
|-------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ASLEEP      | 0   | Asleep. See Sleep mode. After negation of HRESET_B, ASLEEP is asserted until the device completes its power-on reset sequence and reaches its ready state. |                                                                                                                                                                                                                                                                                 |  |
|             |     | State<br>Meaning                                                                                                                                           | Asserted-Indicates that the device is either still in its power-on reset sequence or it has reached a sleep state after a power-down command is issued by software.                                                                                                             |  |
|             |     |                                                                                                                                                            | Negated-The device is not in sleep mode. (It has either awakened from a power-down state, or has completed the POR sequence.)                                                                                                                                                   |  |
|             |     | Timing                                                                                                                                                     | Assertion-May occur at any time; may be asserted asynchronously to the input clocks.                                                                                                                                                                                            |  |
|             |     |                                                                                                                                                            | Negation-Negates synchronously with SYSCLK when leaving power-on sequence; otherwise negation is asynchronous.                                                                                                                                                                  |  |
| CKSTP_IN0_B | I   | Checkstop                                                                                                                                                  | o in 0.                                                                                                                                                                                                                                                                         |  |
|             |     | State<br>Meaning                                                                                                                                           | Asserted-Indicates that the e500 core 0 must enter a hard stop condition. All e500 clocks are turned off. CKSTP_OUT0_B is asserted. The rest of the device logic, including memory controllers, internal memories and registers, and I/O interfaces, remains functional.        |  |
|             |     |                                                                                                                                                            | Negated-Indicates that normal operation should proceed.                                                                                                                                                                                                                         |  |
|             |     | Timing                                                                                                                                                     | Assertion-May occur at any time; may be asserted asynchronously to the input clocks.                                                                                                                                                                                            |  |
|             |     |                                                                                                                                                            | Negation-Must remain asserted until the device is reset with assertion of HRESET_B.                                                                                                                                                                                             |  |
| CKSTP_IN1_B | I   | Checkstop in 1.                                                                                                                                            |                                                                                                                                                                                                                                                                                 |  |
|             |     | State<br>Meaning                                                                                                                                           | Asserted-Indicates that the e500 core 1 must enter a hard stop condition. All e500 core 1 clocks are turned off. CKSTP_OUT1_B is asserted. The rest of the device logic, including memory controllers, internal memories and registers, and I/O interfaces, remains functional. |  |
|             |     |                                                                                                                                                            | Negated-Indicates that normal operation should proceed.                                                                                                                                                                                                                         |  |
|             |     | Timing                                                                                                                                                     | Assertion-May occur at any time; may be asserted asynchronously to the input clocks.                                                                                                                                                                                            |  |
|             |     |                                                                                                                                                            | Negation-Must remain asserted until the device is reset with assertion of HRESET_B.                                                                                                                                                                                             |  |
| CKSTP_OUT0  | 0   | Checkstop                                                                                                                                                  | o out 0.                                                                                                                                                                                                                                                                        |  |
| _B          |     | State<br>Meaning                                                                                                                                           | Asserted-Indicates that the e500 core 0 of the device is in a checkstop state. The rest of the device logic remains functional.                                                                                                                                                 |  |
|             |     |                                                                                                                                                            | Negated-Indicates normal operation. After CKSTP_OUT0_B has been asserted, it is negated after the next negation (low-to-high transition) of HRESET_B.                                                                                                                           |  |
|             |     | Timing                                                                                                                                                     | Assertion-May occur at any time; may be asserted asynchronously to the input clocks.                                                                                                                                                                                            |  |
|             |     |                                                                                                                                                            | Negation-Must remain asserted until the device has been reset with a hard reset.                                                                                                                                                                                                |  |
| CKSTP_OUT1  | 0   | Checkstop                                                                                                                                                  | o out 1.                                                                                                                                                                                                                                                                        |  |
| _B          |     | State Asserted-Indicates that the e500 core 1 of the device is in a checkstop state. The rest of the Meaning device logic remains functional.              |                                                                                                                                                                                                                                                                                 |  |
|             |     | Negated-Indicates normal operation. After CKSTP_OUT1_B has been asserted, it is negated after the next negation (low-to-high transition) of HRESET_B.      |                                                                                                                                                                                                                                                                                 |  |
|             |     | Timing Assertion-May occur at any time; may be asserted asynchronously to the input clocks.                                                                |                                                                                                                                                                                                                                                                                 |  |
|             |     |                                                                                                                                                            | Negation-Must remain asserted until the device has been reset with a hard reset.                                                                                                                                                                                                |  |

Table 20-2. Detailed signal descriptions (continued)

| Signal  | 1/0 |         | Description                                                                                        |  |  |  |  |
|---------|-----|---------|----------------------------------------------------------------------------------------------------|--|--|--|--|
| CLK_OUT |     | l       | Clock out. Reflects clock signal selected by CLKOCR (see Clock out control register GUTS_CLKOCR)). |  |  |  |  |
|         |     | State   |                                                                                                    |  |  |  |  |
|         |     | Meaning | High impedance-If CLKOCR[ENB] = 0.                                                                 |  |  |  |  |
|         |     | Timing  | Timing Assertion/Negation-Depends on the value of CLKOCR[CLK_SEL].                                 |  |  |  |  |

## 20.5 GUTS Memory Map/Register Definition

The table below summarizes the global utilities registers and their addresses.

#### **GUTS** memory map

| Offset<br>address<br>(hex) | Register name                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_0000                     | POR PLL ratio status register (GUTS_PORPLLSR)                 | 32                 | R      | See section | 20.5.1/1521      |
| E_0004                     | POR boot mode status register (GUTS_PORBMSR)                  | 32                 | R      | See section | 20.5.2/1524      |
| E_000C                     | POR device status register (GUTS_PORDEVSR)                    | 32                 | R      | See section | 20.5.3/1526      |
| E_0010                     | POR debug mode status register (GUTS_PORDBGMSR)               | 32                 | R      | See section | 20.5.4/1529      |
| E_0014                     | POR device status register 2 (GUTS_PORDEVSR2)                 | 32                 | R      | See section | 20.5.5/1531      |
| E_0020                     | General-purpose POR configuration register (GUTS_GPPORCR)     | 32                 | R      | See section | 20.5.6/1533      |
| E_0060                     | Alternate function signal multiplex control (GUTS_PMUXCR)     | 32                 | R/W    | 0000_0000h  | 20.5.7/1534      |
| E_0070                     | Device disable register (GUTS_DEVDISR)                        | 32                 | R/W    | See section | 20.5.8/1536      |
| E_0080                     | Power management control and status register (GUTS_POWMGTCSR) | 32                 | R/W    | 0000_0000h  | 20.5.9/1540      |
| E_008C                     | Power management clock disable register (GUTS_PMCDR)          | 32                 | R/W    | 0000_00E0h  | 20.5.10/<br>1543 |
| E_0090                     | Machine check summary register (GUTS_MCPSUMR)                 | 32                 | w1c    | 0000_0000h  | 20.5.11/<br>1544 |
| E_0094                     | Reset request status and control register (GUTS_RSTRSCR)      | 32                 | R      | 0000_0000h  | 20.5.12/<br>1547 |
| E_0098                     | Exception reset control register (GUTS_ECTRSTCR)              | 32                 | R/W    | 0000_0000h  | 20.5.13/<br>1548 |
| E_009C                     | Automatic reset status register (GUTS_AUTORSTSR)              | 32                 | w1c    | 0000_0000h  | 20.5.14/<br>1550 |
| E_00A0                     | Processor version register (GUTS_PVR)                         | 32                 | R      | 8021_2050h  | 20.5.15/<br>1552 |

## **GUTS** memory map (continued)

| Offset address (hex) | Register name                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|--------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_00A4               | System version register (GUTS_SVR)                           | 32                 | R      | See section | 20.5.16/<br>1552 |
| E_00B0               | Reset control register (GUTS_RSTCR)                          | 32                 | R/W    | 0000_0000h  | 20.5.17/<br>1553 |
| E_00C0               | I/O voltage select status register (GUTS_IOVSELSR)           | 32                 | R      | 0000_0000h  | 20.5.18/<br>1554 |
| E_0100               | Open drain register (GUTS_CPODRA)                            | 32                 | R/W    | 0000_0000h  | 20.5.19/<br>1555 |
| E_0104               | Data register (GUTS_CPDATA)                                  | 32                 | R/W    | 0000_0000h  | 20.5.20/<br>1555 |
| E_0108               | Direction register (GUTS_CPDIR1A)                            | 32                 | R/W    | 0000_0000h  | 20.5.21/<br>1556 |
| E_010C               | Direction register (GUTS_CPDIR2A)                            | 32                 | R/W    | 0000_0000h  | 20.5.22/<br>1557 |
| E_0110               | Pin assignment register (GUTS_CPPAR1A)                       | 32                 | R/W    | 0000_0000h  | 20.5.23/<br>1557 |
| E_0114               | Pin assignment register (GUTS_CPPAR2A)                       | 32                 | R/W    | 0000_0000h  | 20.5.24/<br>1558 |
| E_0120               | Open drain register (GUTS_CPODRB)                            | 32                 | R/W    | 0000_0000h  | 20.5.19/<br>1555 |
| E_0124               | Data register (GUTS_CPDATB)                                  | 32                 | R/W    | 0000_0000h  | 20.5.20/<br>1555 |
| E_0128               | Direction register (GUTS_CPDIR1B)                            | 32                 | R/W    | 0000_0000h  | 20.5.21/<br>1556 |
| E_012C               | Direction register (GUTS_CPDIR2B)                            | 32                 | R/W    | 0000_0000h  | 20.5.22/<br>1557 |
| E_0130               | Pin assignment register (GUTS_CPPAR1B)                       | 32                 | R/W    | 0000_0000h  | 20.5.23/<br>1557 |
| E_0134               | Pin assignment register (GUTS_CPPAR2B)                       | 32                 | R/W    | 0000_0000h  | 20.5.24/<br>1558 |
| E_0140               | Open drain register (GUTS_CPODRC)                            | 32                 | R/W    | 0000_0000h  | 20.5.19/<br>1555 |
| E_0144               | Data register (GUTS_CPDATC)                                  | 32                 | R/W    | 0000_0000h  | 20.5.20/<br>1555 |
| E_0148               | Direction register (GUTS_CPDIR1C)                            | 32                 | R/W    | 0000_0000h  | 20.5.21/<br>1556 |
| E_014C               | Direction register (GUTS_CPDIR2C)                            | 32                 | R/W    | 0000_0000h  | 20.5.22/<br>1557 |
| E_0150               | Pin assignment register (GUTS_CPPAR1C)                       | 32                 | R/W    | 0000_0000h  | 20.5.23/<br>1557 |
| E_0154               | Pin assignment register (GUTS_CPPAR2C)                       | 32                 | R/W    | 0000_0000h  | 20.5.24/<br>1558 |
| E_0200               | CE Interrupt multiplexing control register n (GUTS_CEIMXCR0) | 32                 | R/W    | 0000_0000h  | 20.5.25/<br>1559 |

#### **GUTS Memory Map/Register Definition**

## **GUTS** memory map (continued)

| Offset<br>address<br>(hex) | Register name                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------------|--------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_0204                     | CE Interrupt multiplexing control register n (GUTS_CEIMXCR1) | 32                 | R/W    | 0000_0000h  | 20.5.25/<br>1559 |
| E_0208                     | CE Interrupt multiplexing control register n (GUTS_CEIMXCR2) | 32                 | R/W    | 0000_0000h  | 20.5.25/<br>1559 |
| E_020C                     | CE Interrupt multiplexing control register n (GUTS_CEIMXCR3) | 32                 | R/W    | 0000_0000h  | 20.5.25/<br>1559 |
| E_0210                     | CE Interrupt mask register (GUTS_CEIMXMASK)                  | 32                 | R/W    | 0000_0000h  | 20.5.26/<br>1559 |
| E_0214                     | CE Interrupt polarity register (GUTS_CEIMXPOLAR)             | 32                 | R/W    | 0000_0000h  | 20.5.27/<br>1561 |
| E_0B28                     | DDR clock disable register (GUTS_DDRCLKDR)                   | 32                 | R/W    | 0000_0000h  | 20.5.28/<br>1562 |
| E_0E00                     | Clock out control register (GUTS_CLKOCR)                     | 32                 | R/W    | 0000_0000h  | 20.5.29/<br>1563 |
| E_0E20                     | ECM control register (GUTS_ECMCR)                            | 32                 | R/W    | 0000_0000h  | 20.5.30/<br>1564 |
| E_3000                     | SRDS Control Register 0 (GUTS_SRDSCR0)                       | 32                 | R/W    | See section | 20.5.31/<br>1565 |
| E_3004                     | SRDS Control Register 1 (GUTS_SRDSCR1)                       | 32                 | R/W    | See section | 20.5.32/<br>1567 |
| E_3008                     | SRDS Control Register 2 (GUTS_SRDSCR2)                       | 32                 | R/W    | 0000_0040h  | 20.5.33/<br>1568 |
| E_300C                     | SRDS Control Register 3 (GUTS_SRDSCR3)                       | 32                 | R/W    | 0000_0000h  | 20.5.34/<br>1570 |
| E_3010                     | SRDS Control Register 4 (GUTS_SRDSCR4)                       | 32                 | R/W    | 0000_0000h  | 20.5.35/<br>1573 |

## 20.5.1 POR PLL ratio status register (GUTS\_PORPLLSR)

PORPLLSR, shown in the figure below, contains the settings for the PLL ratios as set by the cfg\_sys\_pll[0:2], cfg\_ddr\_pll[0:2], cfg\_core0\_pll[0:2], and cfg\_core1\_pll[0:2] POR configuration pins . See System PLL ratio , DDR PLL ratio , and e500 core PLL ratios , for more information.



## **GUTS\_PORPLLSR** field descriptions

| Field                 | Description                                                                                                                                                                                                               |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1                   | This field is reserved. Reserved                                                                                                                                                                                          |
|                       |                                                                                                                                                                                                                           |
| 2–7<br>e500_1_Ratio   | Clock ratio between the e500 core 1 and the CCB clock. The 3 lsbs of this field correspond to the values on cfg_core1_pll[0:2] at the negation of HRESET_B. Patterns not shown are reserved. (See e500 core PLL ratios .) |
|                       | 000010 1:1                                                                                                                                                                                                                |
|                       | 000011 3:2                                                                                                                                                                                                                |
|                       | 000100 2:1                                                                                                                                                                                                                |
|                       | 000101 5:2                                                                                                                                                                                                                |
|                       | 000110 3:1                                                                                                                                                                                                                |
|                       | 000111 7:2                                                                                                                                                                                                                |
|                       | 001000 4:1                                                                                                                                                                                                                |
|                       | 001001 9:2                                                                                                                                                                                                                |
| 8–9<br>-              | This field is reserved. Reserved                                                                                                                                                                                          |
| 10-15<br>e500_0_Ratio | Clock ratio between the e500 core 0 and the CCB clock. The 3 lsbs of this field correspond to the values on cfg_core0_pll[0:2] at the negation of HRESET_B. Patterns not shown are reserved. (See e500 core PLL ratios .) |
|                       | 000010 1:1                                                                                                                                                                                                                |
|                       | 000011 3:2                                                                                                                                                                                                                |
|                       | 000100 2:1                                                                                                                                                                                                                |
|                       | 000101 5:2                                                                                                                                                                                                                |
|                       | 000110 3:1                                                                                                                                                                                                                |
|                       | 000111 7:2                                                                                                                                                                                                                |
|                       | 001000 4:1                                                                                                                                                                                                                |
|                       | 001001 9:2                                                                                                                                                                                                                |
| 16–17<br>-            | This field is reserved. Reserved                                                                                                                                                                                          |
| 18–22<br>DDR_Ratio    | Clock ratio between the DDR Complex clock and DDRCLK. Patterns not shown are reserved.                                                                                                                                    |
| ****                  | 00011 3:1                                                                                                                                                                                                                 |
|                       | 00100 4:1                                                                                                                                                                                                                 |
|                       | 00110 6:1                                                                                                                                                                                                                 |
|                       | 01000 8:1                                                                                                                                                                                                                 |
|                       | 01010 10:1                                                                                                                                                                                                                |
|                       | 01100 12:1                                                                                                                                                                                                                |
|                       | 01110 Reserved                                                                                                                                                                                                            |
|                       | 00111 Synchronous Mode-DDR Complex Clocked by CCB clock                                                                                                                                                                   |
| 23–25<br>-            | This field is reserved. Reserved                                                                                                                                                                                          |
| 26-30<br>Plat_Ratio   | Clock ratio between the CCB (platform) clock and SYSCLK. Patterns not shown are reserved.                                                                                                                                 |
|                       | 00100 4:1                                                                                                                                                                                                                 |
|                       | 00101 5:1                                                                                                                                                                                                                 |
|                       | 00110 6:1                                                                                                                                                                                                                 |
|                       | 01000 8:1                                                                                                                                                                                                                 |

## **GUTS\_PORPLLSR** field descriptions (continued)

| Field   | Description                      |
|---------|----------------------------------|
|         | 01010 10:1<br>01100 12:1         |
| 31<br>- | This field is reserved. Reserved |

## 20.5.2 POR boot mode status register (GUTS\_PORBMSR)

The PORBMSR, shown in the figure below, reports setting of the POR configuration pins that control the boot mode settings (described in Boot ROM location, CPU boot configuration, and Boot sequencer configuration) and the default settings of PCI Express host/agent mode (described in Host/agent configuration).



## **GUTS\_PORBMSR** field descriptions

| Field       | Description                                                                                                                                                                                               |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–1         | CPU boot configuration (See CPU boot configuration .)                                                                                                                                                     |
| BCFG        | For BCFG: cfg_cpu0_boot, cfg_cpu1_boot, see Table 4-15.                                                                                                                                                   |
| 2–3<br>-    | This field is reserved. Reserved                                                                                                                                                                          |
| 4–7         | Location of boot ROM. (See Boot ROM location .)                                                                                                                                                           |
| ROM_LOC     | For ROM_LOC: cfg_rom_loc[0:3], see Table 4-12.                                                                                                                                                            |
| 8–9<br>-    | This field is reserved. Reserved                                                                                                                                                                          |
| 10–11       | Boot sequencer configuration (See Boot sequencer configuration .)                                                                                                                                         |
| BSCFG       | For BSCFG: cfg_boot_seq[0:1], see Table 4-16.                                                                                                                                                             |
| 12<br>-     | This field is reserved. Reserved                                                                                                                                                                          |
| 13–15<br>HA | Host/agent mode configuration. When the device is an agent on an interface, it is prevented from mastering transactions on that interface until the external host configures the interface appropriately. |
|             | (See Host/agent configuration .)                                                                                                                                                                          |
|             | For HA: cfg_host_agt[0:2], see Table 4-13.                                                                                                                                                                |
| 16–31<br>-  | This field is reserved. Reserved                                                                                                                                                                          |

## 20.5.3 POR device status register (GUTS\_PORDEVSR)

Shown in the figure below, PORDEVSR reports other POR settings for I/O devices as described in SerDes reference clock configuration , and eTSECn configuration .







### **GUTS\_PORDEVSR** field descriptions

| Field      | Description                                             |
|------------|---------------------------------------------------------|
| 0          | eTSEC1 controller width (See eTSECn configuration .)    |
| ECW        | For ECW: cfg_tsec_reduce, see Table 4-19                |
| 1–3<br>-   | This field is reserved. Reserved                        |
| 4          | eTSEC3 SGMII mode disabled (See eTSECn configuration .) |
| SGMII3_DIS | For SGMII3_DIS: cfg_sgmii3, see Table 4-20.             |
| 5          | This field is reserved.                                 |
| -          | Reserved                                                |
| 6–7        | eTSEC1 controller protocol (See eTSECn configuration .) |
| ECP1       | For ECP1: cfg_tsec1_prtcl[0:1], see Table 4-20.         |
| 8          | This field is reserved.                                 |
| -          | Reserved                                                |
| 9–12       | I/O port selection mode (See I/O port selection .)      |
| IO_SEL     | For IO_SEL: cfg_io_ports[0:3], see Table 4-14.          |
| 13–14      | This field is reserved.                                 |
| -          | Reserved                                                |

#### **GUTS Memory Map/Register Definition**

## **GUTS\_PORDEVSR** field descriptions (continued)

| Field | Description                                                       |
|-------|-------------------------------------------------------------------|
| 15    | eLBC ECC enable (See eLBC ECC enable configuration .)             |
| LECC  | For LECC: cfg_elbc_ecc, see Table 4-29.                           |
| 16–19 | This field is reserved.                                           |
| -     | Reserved                                                          |
| 20–21 | eTSEC3 controller protocol (See eTSECn configuration .)           |
| ECP3  | For ECP3: cfg_tsec3_prtcl[0:1], see Table 4-20.                   |
| 22–24 | This field is reserved.                                           |
| -     | Reserved                                                          |
| 25    | DRAM type for DDR Controller (See DDR SDRAM type .) cfg_dram_type |
| RTYPE | For RTYPE: cfg_dram_type, see Table 4-17.                         |
| 26–31 | This field is reserved.                                           |
| -     | Reserved                                                          |

## 20.5.4 POR debug mode status register (GUTS\_PORDBGMSR)

PORDBGMSR, shown in the figure below, holds debug mode settings from the POR configuration pins as described in Memory debug configuration , and DDR debug configuration .





#### **GUTS Memory Map/Register Definition**



#### **GUTS\_PORDBGMSR** field descriptions

| Field        | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| 0–4          | This field is reserved. Reserved                                                                               |
| 5<br>MEM_SEL | Memory select. Indicates which controller is driving MSRCID[0:4] and MDVAL. (See Memory debug configuration .) |
|              | For MEM_SEL: cfg_mem_debug, see Table 4-25.                                                                    |
| 6 -          | This field is reserved. Reserved                                                                               |
| 7            | DDR controller debug configuration (See DDR debug configuration .)                                             |
| DDR_DBG      | For DDR_DBG: cfg_ddr_debug, see Table 4-26.                                                                    |
| 8–31<br>-    | This field is reserved. Reserved                                                                               |

## 20.5.5 POR device status register 2 (GUTS\_PORDEVSR2)

Address: E\_0000h base + 14h offset = E\_0014h



#### **GUTS Memory Map/Register Definition**



## **GUTS\_PORDEVSR2** field descriptions

| Field           | Description                                                         |
|-----------------|---------------------------------------------------------------------|
| 0–7             | This field is reserved. Reserved                                    |
| 8               | For future engineering use 6 (driven by POR reset signal)           |
| ENG_USE6        | For ENG_USE6: cfg_eng_use6, see Table 4-28                          |
| 9–10<br>-       | This field is reserved. Reserved                                    |
| 11              | For future engineering use 3 (driven by POR reset signal)           |
| ENG_USE3        | For ENG_USE3: cfg_eng_use3, see Engineering use POR configuration . |
| 12              | Core 0 Speed (see Core 0 speed )                                    |
| CORE0_SPEED     | For CORE0_SPEED: cfg_core0_speed, see Table 4-32.                   |
| 13              | Core 1 Speed (see Core 1 speed )                                    |
| CORE1_SPEED     | For CORE1_SPEED: cfg_core1_speed, see Table 4-33.                   |
| 14              | Platform 0 Speed (see Platform speed )                              |
| PLAT_SPEED0     | For PLAT_SPEED0: cfg_plat_speed, see Table 4-31.                    |
| 15<br>DDR_SPEED | DDR Speed (see DDR speed )                                          |

#### **GUTS\_PORDEVSR2** field descriptions (continued)

| Field          | Description                                                        |
|----------------|--------------------------------------------------------------------|
|                | For DDR_SPEED: cfg_ddr_speed, see Table 4-34.                      |
| 16–17<br>-     | This field is reserved. Reserved                                   |
| 18             | SerDes reference clock (see SerDes reference clock configuration ) |
| SRDS_REFCLK    | For SRDS_REFCLK: cfg_srds_refclk, see Table 4-18.                  |
| 19–20<br>-     | This field is reserved. Reserved                                   |
| 21             | System Speed (see System speed )                                   |
| SYS_SPEED      | For SYS_SPEED: cfg_sys_speed, see Table 4-30.                      |
| 22             | This field is reserved.                                            |
| -              | Reserved                                                           |
| 23<br>SDHC_CD_ | eSDHC card-detect polarity select                                  |
| POL_SEL        | For SDHC_CD_POL_SEL: cfg_sdhc_cd_pol_sel, see Table 4-35.          |
| 24             | For future engineering use 2 (Driven by POR reset signal)          |
| ENG_USE2       | For ENG_USE2: cfg_eng_use2, see Table 4-28.                        |
| 25             | For future engineering use 1 (Driven by POR reset signal)          |
| ENG_USE1       | For ENG_USE2: cfg_eng_use2, see Table 4-28.                        |
| 26<br>ENG_USE0 | For future engineering use 0 (Driven by POR reset signal)          |
|                | For ENG_USE0: cfg_eng_use0, see Table 4-28.                        |
| 27–31          | This field is reserved. Reserved                                   |
| -              | i lesel veu                                                        |

# 20.5.6 General-purpose POR configuration register (GUTS\_GPPORCR)

GPPORCR stores the value sampled from the local bus address/data signals, LAD[0:15], during POR, as described in General-purpose POR configuration. Software can use this value to inform the operating system about initial system configuration. Typical interpretations include circuit board type, board ID number, or a list of available peripherals.

Address: E\_0000h base + 20h offset = E\_0020h



#### **GUTS\_GPPORCR** field descriptions

| Field      | Description                                                                                                                                                                                                                            |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | General-purpose POR configuration vector sampled from local bus address/data signals LAD[0:15] at the negation of HRESET_B. Note that if nothing is driven on these signals during reset, the value of this register is indeterminate. |
| 16–31<br>- | This field is reserved. Reserved                                                                                                                                                                                                       |

# 20.5.7 Alternate function signal multiplex control (GUTS\_PMUXCR)

Shown in the figure below, PMUXCR contains bits that enable the exposure of an alternate function replacing the pins' primary functions.

Specifically, eSDHC, eTSEC1, eTSEC3, and USB each have features that can be exposed replacing the primary functions of certain SPI and QUICC Engine pins.

CE\_PA[31], CE\_PB[0:7], CE\_PB[11], CE\_PB[29:31], and CE\_PC[0] always functions as QE pins irrespective of the status of PMUXCR bits.

Address: E\_0000h base + 60h offset = E\_0060h



#### **GUTS\_PMUXCR** field descriptions

| Field   | Description                                            |
|---------|--------------------------------------------------------|
| 0       | Exposes SDHC_DAT[4:7] signals used for MMC 8-bit mode. |
| SD_DATA |                                                        |

## **GUTS\_PMUXCR** field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | 0 SDHC_DAT[4:7] is not exposed to pins. The pins retain their primary function as SPI.                                                                                                                                                                                                                                                                                                                                              |
|                      | SDHC_DAT[4:7] is exposed to pins as follows: SPI_CS[0] functions as SDHC_DAT[4], SPI_CS[1] functions as SDHC_DAT[5], SPI_CS[2] functions as SDHC_DAT[6], SPI_CS[3] functions as SDHC_DAT[7]                                                                                                                                                                                                                                         |
| 1<br>SDHC_CD         | Exposes SDHC_CD_B signal used for Secure Digital card detection.                                                                                                                                                                                                                                                                                                                                                                    |
| _                    | <ul><li>The pin functions as CE_PB[12]</li><li>The pin retains its function as SDHC_CD_B.</li></ul>                                                                                                                                                                                                                                                                                                                                 |
| 2<br>SDHC_WP         | Exposes SDHC_WP signal used for Secure Digital write protect detection.                                                                                                                                                                                                                                                                                                                                                             |
| 3DHO_WF              | 0 The pin functions as CE_PB[13] 1 The pin retains its function as SDHC_WP.                                                                                                                                                                                                                                                                                                                                                         |
| 3–4                  | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5–6<br>USB_PCTL      | Exposes USB1_PCTL0 and USB1_PCTL1 signals used for host-mode USB port status indication.                                                                                                                                                                                                                                                                                                                                            |
| 000_1012             | 00 The pins retain their function as CE_PB[8] and CE_PA[15] 01 Reserved                                                                                                                                                                                                                                                                                                                                                             |
|                      | 10 USB_PCTL0 and USB_PCTL1 signals are exposed to pins as follows: CE_PB[8] functions as USB_PCTL0, CE_PA[15] functions as USB_PCTL1                                                                                                                                                                                                                                                                                                |
|                      | 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7–12<br>-            | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13                   | Selects the 125 MHz reference clock source for TSEC1                                                                                                                                                                                                                                                                                                                                                                                |
| TSEC1_GTX_<br>CLK125 | This configuration field provides the option to select a shared or dedicate clock source for TSEC1. When TSEC1 is configured for RGMII, the TSEC1_TX_CLK may be used as 125 MHz reference clock source for TSEC1. Note that 1588 accuracy can be adversely impacted in the systems using multiple unsynchronized gigabit Ethernet ports. To enable IEEE 1588 accuracy in such systems, a dedicated reference clock may be selected. |
|                      | NOTE: TSEC3 always uses EC_GTX_CLK125 and TSEC2 is in SGMII mode only.                                                                                                                                                                                                                                                                                                                                                              |
|                      | 0 Selects EC_GTX_CLK125 as the clock source (shared) 1 Selects TSEC1_TX_CLK as the clock source (dedicated)                                                                                                                                                                                                                                                                                                                         |
| 14–15<br>-           | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16<br>QE0            | Exposes QUICC Engine pins                                                                                                                                                                                                                                                                                                                                                                                                           |
| QE0                  | 0 QUICC Engine pins are not exposed on eLBC and IRQ6 pins                                                                                                                                                                                                                                                                                                                                                                           |
|                      | 1 QUICC Engine pins are exposed as follows:, CE_PA[4:10], CE_PA[17:21], CE_PA[13], CE_PA[25:26], and CE_PA[30] are exposed (instead of LA[16:31]), CE_PA[11:12] are exposed (instead of LDP[0:1]), CE_PA[22:24] and CE_PA[27] are exposed (instead of LCS_B[4:7]), CE_PA[14] is exposed (instead of LGPL5), CE_PA[16] is exposed (instead of LCLK[1]), CE_PB[10] is exposed (instead of IRQ6).                                      |
| 17<br>QE1            | Exposes QUICC Engine pins                                                                                                                                                                                                                                                                                                                                                                                                           |
| QE1                  | 0 QUICC Engine pins are not exposed on LAD[8] 1 CE_PA[0] is exposed on LAD[8]                                                                                                                                                                                                                                                                                                                                                       |
| 18                   | Exposes QUICC Engine pins                                                                                                                                                                                                                                                                                                                                                                                                           |
| QE2                  |                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### **GUTS\_PMUXCR** field descriptions (continued)

| Field      | Description                                                                                                                          |
|------------|--------------------------------------------------------------------------------------------------------------------------------------|
|            | 0 QUICC Engine pins are not exposed on LCLK[0]                                                                                       |
|            | 1 CE_PA[28] is exposed on LCLK[0]                                                                                                    |
| 19         | Exposes QUICC Engine pins                                                                                                            |
| QE3        | 0 QUICC Engine pins are not exposed on LWE1                                                                                          |
|            | 1 CE_PB[9] is exposed on LWE1                                                                                                        |
| 20         | Exposes QUICC Engine pins                                                                                                            |
| QE4        | Exposes Q0100 Engine pins                                                                                                            |
|            | 0 QUICC Engine pins are not exposed on LGPL0, LGPL1, LGPL3                                                                           |
|            | 1 QUICC Engine pins are exposed as, LGPL0 as CE_PA[1], LGPL1 as CE_PA[2], LGPL3 as CE_PA[3]                                          |
| 21–23<br>- | This field is reserved. Reserved                                                                                                     |
| 24         | Exposes QUICC Engine pins                                                                                                            |
| QE8        | 0 QUICC Engine pins are not exposed on UART1                                                                                         |
|            | 1 QUICC Engine pins are exposed on OART1  1 QUICC Engine pins are exposed as, UART_SOUT1 as CE_PB[17], UART_SIN1 as CE_PB[16],       |
|            | UART_CTS1 as CE_PB[14], UART_RTS1 as CE_PB[15]                                                                                       |
| 25<br>QE9  | Exposes QUICC Engine pins                                                                                                            |
|            | 0 QUICC Engine pins are not exposed on configuration pins                                                                            |
|            | 1 QUICC Engine pins are exposed as, CFG_MEM_DEBUG as CE_PB[19], CFG_DDR_DEBUG as CE_PA[29], CE_PB[18] is exposed when QE9 bit is set |
| 26<br>QE10 | Exposes QUICC Engine pins                                                                                                            |
|            | 0 QUICC Engine pins are not exposed on I <sup>2</sup> C2                                                                             |
|            | 1 QUICC Engine pins are exposed as, IIC2_SDA as CE_PB[21], IIC2_SCL as CE_PB[22]                                                     |
| 27<br>QE11 | Exposes QUICC Engine pins                                                                                                            |
|            | 0 QUICC Engine pins are not exposed on debug pins                                                                                    |
|            | 1 QUICC Engine pins are exposed as, MSRCID[0:4] as CE_PB[23:27], MDVAL as CE_PB[28]                                                  |
| 28<br>QE12 | Exposes QUICC Engine pins                                                                                                            |
|            | 0 QUICC Engine pins are not exposed on LBCTL                                                                                         |
| 25.5       | 1 QUICC Engine pins are exposed as, LBCTL as CE_PB[20]                                                                               |
| 29–31<br>- | This field is reserved. Reserved                                                                                                     |

## 20.5.8 Device disable register (GUTS\_DEVDISR)

DEVDISR, shown in the figure below, contains disable bits for various functional blocks.

Note that bits with a reset value of n depend on the state of POR configuration signals at reset.

All functional blocks are enabled after reset; unneeded blocks can be disabled to reduce power consumption. Blocks disabled by DEVDISR must not be re-enabled without a hard reset. Note that timer block (bit [TB0, TB1]) can be enabled or disabled without hard reset. Shutting down unused blocks, has more information on the use of DEVDISR.



#### **GUTS\_DEVDISR field descriptions**

| Field      | Description                                                          |
|------------|----------------------------------------------------------------------|
| 0–1        | This field is reserved. Reserved                                     |
| 2<br>PCIE1 | PCI Express 1 controller disable  0 PCI Express 1 controller enable  |
|            | 1 PCI Express 1 controller disable                                   |
| 3 -        | This field is reserved. Reserved                                     |
| 4<br>LBC   | Local bus controller disable  0 Local bus controller enable          |
|            | 1 Local bus controller disable                                       |
| 5<br>PCIE2 | PCI Express 2 controller disable                                     |
|            | 0 PCI Express 2 controller enable 1 PCI Express 2 controller disable |

## **GUTS\_DEVDISR** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 -         | This field is reserved. Reserved                                                                                                                                                                                                                                                         |
| 7<br>SEC    | Security disable                                                                                                                                                                                                                                                                         |
|             | 0 Security enable 1 Security disable                                                                                                                                                                                                                                                     |
| 8<br>USB    | USB disable                                                                                                                                                                                                                                                                              |
|             | 0 USB enable<br>1 USB disable                                                                                                                                                                                                                                                            |
| 9 -         | This field is reserved. Reserved                                                                                                                                                                                                                                                         |
| 10<br>eSDHC | eSDHC disable                                                                                                                                                                                                                                                                            |
|             | 0 eSDHC enable<br>1 eSDHC disable                                                                                                                                                                                                                                                        |
| 11–14       | This field is reserved. Reserved                                                                                                                                                                                                                                                         |
| 15<br>DDR   | DDR controller disable                                                                                                                                                                                                                                                                   |
| DDIT        | DDR SDRAM controller enable     DDR SDRAM controller disable                                                                                                                                                                                                                             |
| 16          | e500 core 0 disable                                                                                                                                                                                                                                                                      |
| E500_CORE0  | For more information, see Shutting down unused blocks .                                                                                                                                                                                                                                  |
|             | 0 e500 0 core enable                                                                                                                                                                                                                                                                     |
|             | 1 e500 0 core disable. Places the core in the core_stopped state in which it does not respond to interrupts. Equivalent to nap mode. Instruction fetching is stopped, snooping is disabled, and clocks are shut down to all functional units of the core including the timer facilities. |
| 17<br>TB0   | Time base (timer facilities) of the e500 core 0 disable                                                                                                                                                                                                                                  |
| 150         | Timer facilities enabled     Timer facilities disabled                                                                                                                                                                                                                                   |
| 18          | 1 Timer facilities disabled<br>e500 core 1 disable                                                                                                                                                                                                                                       |
| E500_CORE1  | For more information, see Shutting down unused blocks .                                                                                                                                                                                                                                  |
|             | 0 e500 1 core enable                                                                                                                                                                                                                                                                     |
|             | 1 e500 1 core disable. Places the core in the core_stopped state in which it does not respond to interrupts. Equivalent to nap mode. Instruction fetching is stopped, snooping is disabled, and clocks are shut down to all functional units of the core including the timer facilities. |
| 19<br>TB1   | Time base (timer facilities) of the e500 core 1 disable                                                                                                                                                                                                                                  |
| IDI         | 0 Timer facilities enabled                                                                                                                                                                                                                                                               |
|             | 1 Timer facilities disabled                                                                                                                                                                                                                                                              |
| 20<br>QE    | QUICC Engine disable                                                                                                                                                                                                                                                                     |
|             | 0 QUICC Engine enabled                                                                                                                                                                                                                                                                   |
|             | 1 QUICC Engine disabled                                                                                                                                                                                                                                                                  |

## **GUTS\_DEVDISR field descriptions (continued)**

| Field       | Description                                                                                                             |
|-------------|-------------------------------------------------------------------------------------------------------------------------|
| 21<br>DMA   | DMA controller disabled                                                                                                 |
|             | 0 DMA controller enabled                                                                                                |
|             | 1 DMA controller disabled                                                                                               |
| 22–23       | This field is reserved. Reserved                                                                                        |
| 24<br>TSEC1 | Three-speed Ethernet controller 1 disable  NOTE: Ethernet management interface is not available when TSEC1 is disabled. |
|             |                                                                                                                         |
|             | 0 eTSEC1 enabled                                                                                                        |
|             | 1 eTSEC1 disabled                                                                                                       |
| 25<br>TSEC2 | Three-speed Ethernet controller 2 disable                                                                               |
|             | 0 eTSEC2 enabled 1 eTSEC2 disabled                                                                                      |
| 26          |                                                                                                                         |
| TSEC3       | Three-speed Ethernet controller 3 disable                                                                               |
|             | 0 eTSEC3 enabled                                                                                                        |
|             | 1 eTSEC3 disabled                                                                                                       |
| 27          | This field is reserved.                                                                                                 |
| -           | Reserved                                                                                                                |
| 28<br>SPI   | SPI controller disable                                                                                                  |
|             | 0 SPI enabled                                                                                                           |
|             | 1 SPI disabled                                                                                                          |
| 29<br>I2C   | I <sup>2</sup> C controllers disabled                                                                                   |
|             | 0 I <sup>2</sup> C controllers enabled                                                                                  |
|             | 1 I <sup>2</sup> C controllers disabled                                                                                 |
| 30<br>DUART | Dual UART controller disabled                                                                                           |
|             | 0 DUART enabled                                                                                                         |
|             | 1 DUART disabled                                                                                                        |
| 31          | This field is reserved.                                                                                                 |
| -           | Reserved                                                                                                                |

# 20.5.9 Power management control and status register (GUTS\_POWMGTCSR)

Shown in the figure below, POWMGTCSR contains bits for placing the device into low power states and for controlling when it wakes up. It also contains power management status bits. See Interrupts and power management controlled by POWMGTCSR, for more information.



## **GUTS\_POWMGTCSR** field descriptions

| Field                   | Description                                                                                                                                                                                                                              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                       | Core 0 interrupt input mask                                                                                                                                                                                                              |
| CORE0_IRQ_<br>MSK       | 0 Interrupts cause the device to wake up from a low-power state.                                                                                                                                                                         |
|                         | 1 Interrupts are masked as a wake-up condition. The device remains in a low-power state despite the<br>presence of an interrupt request.                                                                                                 |
| 1<br>CORE0_CI_MSK       | Core 0 critical interrupt input mask                                                                                                                                                                                                     |
|                         | O Critical interrupts cause the device to wake up from a low power state.                                                                                                                                                                |
|                         | Critical interrupts are masked as a wake-up condition. The device remains in a low-power state despite the presence of a critical interrupt.                                                                                             |
| 2<br>CORE1_IRQ_         | Core 1 interrupt input mask                                                                                                                                                                                                              |
| MSK                     | 0 Interrupts cause the device to wake up from a low-power state.                                                                                                                                                                         |
|                         | 1 Interrupts are masked as a wake-up condition. The device remains in a low-power state despite the presence of an interrupt request.                                                                                                    |
| 3<br>CORE1_CI_MSK       | Core 1 critical interrupt input mask                                                                                                                                                                                                     |
|                         | O Critical interrupts cause the device to wake up from a low power state.                                                                                                                                                                |
|                         | Critical interrupts are masked as a wake-up condition. The device remains in a low-power state despite the presence of a critical interrupt.                                                                                             |
| 4–11                    | This field is reserved. Reserved                                                                                                                                                                                                         |
| 12                      | Core 0 doze mode                                                                                                                                                                                                                         |
| CORE0_DOZ               | No request to put device in doze mode. Note that this bit is automatically cleared on MCP_B, UDE_B, SRESET_B, core_tbint (from the core) and also int_B and cint_B if not masked.                                                        |
|                         | 1 Device is to be placed in doze mode. Instruction fetching is halted in the e500 core 0. Note that this bit is logically ORed with HID0[DOZE].                                                                                          |
| 13<br>CORE1_DOZ         | Core 1 doze mode.                                                                                                                                                                                                                        |
|                         | No request to put device in doze mode. Note that this bit is automatically cleared on MCP_B, UDE_B, SRESET_B, core_tbint (from the core) and also int_B and cint_B if not masked.                                                        |
|                         | 1 Device is to be placed in doze mode. Instruction fetching is halted in the e500 core 1. Note that this bit is logically ORed with HID0[DOZE].                                                                                          |
| 14<br>SLP               | Sleep mode                                                                                                                                                                                                                               |
|                         | 0 No request to put device in sleep mode.                                                                                                                                                                                                |
|                         | Device is to be placed in sleep mode. Instruction fetching is halted, snooping of L1 caches is disabled, and most functional blocks are shut down in both the e500 cores and the system logic.                                           |
| 15–25<br>-              | This field is reserved. Reserved                                                                                                                                                                                                         |
| 26<br>CORE1_DOZING      | Core 1 doze status                                                                                                                                                                                                                       |
|                         | 0 Device is not in doze mode.                                                                                                                                                                                                            |
|                         | 1 The device is in doze mode because POWMGTCSR[DOZ] is set or because HID0[DOZE] and MSR[WE] (in the e500 core 1) are set. The core has halted instruction fetching, but all other functional blocks in the core and device are running. |
| 27<br>CORE1_<br>NAPPING | Core 1 nap status                                                                                                                                                                                                                        |

#### **GUTS Memory Map/Register Definition**

## **GUTS\_POWMGTCSR** field descriptions (continued)

| Field              | Description                                                                                                                                                                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 0 Device is not in nap mode.                                                                                                                                                                                                                                                                            |
|                    | 1 The device is in nap mode because HID0[NAP] and MSR[WE] are set. The core has halted instruction fetching, snooping of the L1 caches is disabled, and all of the core's functional units except the timer facilities are shut down. All functional blocks in the device are running.                  |
| 28<br>CORE0_DOZING | Core 0 doze status                                                                                                                                                                                                                                                                                      |
|                    | 0 Device is not in doze mode.                                                                                                                                                                                                                                                                           |
|                    | 1 The device is in doze mode because POWMGTCSR[DOZ] is set or because HID0[DOZE] and MSR[WE] (in the e500 core 0) are set. The core has halted instruction fetching, but all other functional blocks in the core and device are running.                                                                |
| 29<br>CORE0        | Core 0 nap status                                                                                                                                                                                                                                                                                       |
| NAPPING            | 0 Device is not in nap mode.                                                                                                                                                                                                                                                                            |
|                    | 1 The device is in nap mode because HID0[NAP] and MSR[WE] are set. The core has halted instruction fetching, snooping of the L1 caches is disabled, and all of the core's functional units except the timer facilities are shut down. All functional blocks in the device are running.                  |
| 30<br>SLPING       | Sleep status                                                                                                                                                                                                                                                                                            |
|                    | 0 Device is not attempting to reach sleep mode.                                                                                                                                                                                                                                                         |
|                    | 1 The device is attempting to SLEEP because POWMGTCSR[SLP] is set or because HID0[SLEEP] and MSR[WE] (in the e500 core) are set. Most functional blocks in the core and device are shut down or are attempting to shut down.                                                                            |
| 31<br>QSCED        | Quiesce status                                                                                                                                                                                                                                                                                          |
|                    | 0 Device is not in quiesce mode.                                                                                                                                                                                                                                                                        |
|                    | 1 The device is quiesced because POWMGTCSR[QSC] is set, or because of a device debug event. All memories, configuration registers, and most I/O blocks are accessible, but only the system access port (SAP) may master reads and writes into the device. All other mastering interfaces are shut down. |

# 20.5.10 Power management clock disable register (GUTS\_PMCDR)

The power management clock disable register (PMCDR) is shown in the figure below. The register contains disable bits for various functional blocks. The register determine the blocks which will shut down the clock in the sleep power states.



#### **GUTS\_PMCDR** field descriptions

| Field      | Description                                                    |
|------------|----------------------------------------------------------------|
| 0–23<br>-  | This field is reserved. Reserved                               |
| 24         | Three-speed Ethernet controller 1 disable clock in sleep mode. |
| TSEC1      | 0 eTSEC1 enabled clock                                         |
|            | 1 eTSEC1 disabled clock                                        |
| 25         | Three-speed Ethernet controller 2 disable clock in sleep mode. |
| TSEC2      | 0 eTSEC2 enabled clock                                         |
|            | 1 eTSEC2 disabled clock                                        |
| 26         | Three-speed Ethernet controller 3 disable clock in sleep mode. |
| TSEC3      | 0 eTSEC3 enabled clock                                         |
|            | 1 eTSEC3 disabled clock                                        |
| 27–31<br>- | This field is reserved. Reserved                               |

## 20.5.11 Machine check summary register (GUTS\_MCPSUMR)

Shown in the figure below, MCPSUMR contains bits summarizing some of the sources of a pending machine check interrupt. All MCPSUMR bits function as write-1-to-clear.

#### NOTE

Register fields designated as write-1-to-clear are cleared only by writing ones to them. Writing zeros to them has no effect.

Note that other conditions can cause a machine check condition not summarized in MCPSUMR. For example, read errors that are not correctable cause the assertion of  $core\_fault\_in$ , which may directly cause a machine check (if HID1[RFXE] = 1). If RFXE = 0, the assertion of  $core\_fault\_in$  does not directly cause a machine check interrupt, but must be handled by the block that generated the error. For more information about RFXE, see Summary of core integration details.







#### **GUTS\_MCPSUMR** field descriptions

| Field          | Description                                                                                                                                                                                                                                |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–23<br>-      | This field is reserved. Reserved                                                                                                                                                                                                           |
| 24<br>CKSTP_P0 | MCP_RSP_CKSTP_P0. Machine check to core 0 in response to checkstop from core 0                                                                                                                                                             |
| _              | 0 Machine check exception was not caused by checkstop of core 0                                                                                                                                                                            |
|                | 1 Machine check exception was caused by checkstop of core 0                                                                                                                                                                                |
| 25<br>CKSTP_P1 | MCP_RSP_CKSTP_P1. Machine check to core 1 in response to checkstop from core 1                                                                                                                                                             |
|                | Machine check exception was not caused by checkstop of core 1                                                                                                                                                                              |
|                | 1 Machine check exception was caused by checkstop of core 1                                                                                                                                                                                |
| 26<br>WRS1     | Core 1 watchdog timer machine check                                                                                                                                                                                                        |
|                | Machine check exception was not caused by watchdog timer.                                                                                                                                                                                  |
|                | Machine check was caused by a soft reset condition from the e500_1 watchdog timer as configured in<br>the core1's TSR. Specifically, TSR[WRS] = 01 and a watchdog reset condition occurred. (See<br>Summary of core integration details .) |
| 27<br>MCP1_IN  | MCP1_B signal asserted                                                                                                                                                                                                                     |
|                | 0 Machine check exception was not caused by MCP1_B assertion.                                                                                                                                                                              |
|                | 1 Machine check exception was caused by the assertion of the MCP1_B input signal.                                                                                                                                                          |
| 28             | This field is reserved. Reserved                                                                                                                                                                                                           |
| 29<br>WRS0     | Core 0 watchdog timer machine check                                                                                                                                                                                                        |
|                | 0 Machine check exception was not caused by watchdog timer.                                                                                                                                                                                |
|                | 1 Machine check was caused by a soft reset condition from the e500_core0 watchdog timer as configured in the core0's TSR. Specifically, TSR[WRS] = 01 and a watchdog reset condition occurred. (See Summary of core integration details .) |

#### **GUTS Memory Map/Register Definition**

## **GUTS\_MCPSUMR** field descriptions (continued)

| Field        | Description                                                                         |
|--------------|-------------------------------------------------------------------------------------|
| 30<br>SRESET | Soft reset machine check                                                            |
|              | Machine check exception was not caused by SRESET_B assertion.                       |
|              | 1 Machine check exception was caused by the assertion of the SRESET_B input signal. |
| 31           | MCP0_B signal asserted                                                              |
| MCP0_IN      |                                                                                     |
|              | Machine check exception was not caused by MCP0_B assertion.                         |
|              | 1 Machine check exception was caused by the assertion of the MCP0_B input signal.   |

# 20.5.12 Reset request status and control register (GUTS\_RSTRSCR)

Shown in the figure below, the RSTRSCR contains status for boot sequencer, watchdog timer, and a software settable reset request bit.



**GUTS\_RSTRSCR** field descriptions

| Field         | Description                                     |
|---------------|-------------------------------------------------|
| 0–8           | This field is reserved. Reserved                |
| 9<br>NFLSH_RR | NAND Flash ECC error during boot reset request. |

#### **GUTS Memory Map/Register Definition**

#### **GUTS\_RSTRSCR** field descriptions (continued)

| Field         | Description                                                                                                                                                        |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10<br>BS_RR   | Boot sequence reset request                                                                                                                                        |
| 11<br>WDT0_RR | Watchdog timer reset request in core 0. Occurs when TSR[WRS] = 10 for core 0 and a watchdog reset condition is reached. (See Summary of core integration details.) |
| 12<br>SW_RR   | Software settable reset request                                                                                                                                    |
| 13<br>WDT1_RR | Watchdog timer reset request in core 1. Occurs when TSR[WRS] = 10 for core 0 and a watchdog reset condition is reached. (See Summary of core integration details.) |
| 14–31<br>-    | This field is reserved. Reserved                                                                                                                                   |

## 20.5.13 Exception reset control register (GUTS\_ECTRSTCR)

Shown in the figure below, the ECTRSTCR contains control bits for the exception reset of core 0 and core 1 in response to checkstop.





#### **GUTS\_ECTRSTCR** field descriptions

| Field                    | Description                                               |
|--------------------------|-----------------------------------------------------------|
| 0<br>RST_CKSTP_<br>P0_EN | Enable automatic reset of core 0 in response to checkstop |

## **GUTS\_ECTRSTCR** field descriptions (continued)

| Field                        | Description                                                          |  |  |  |
|------------------------------|----------------------------------------------------------------------|--|--|--|
| 1<br>RST_CKSTP_<br>P1_EN     | Enable automatic reset of core 1 in response to checkstop            |  |  |  |
| 2–3<br>-                     | This field is reserved. Reserved                                     |  |  |  |
| 4<br>CKSTP_OUT0_<br>DIS      | Disable assertion of CKSTP_OUT0_B pin                                |  |  |  |
| 5<br>CKSTP_OUT1_<br>DIS      | Disable assertion of CKSTP_OUT1_B pin                                |  |  |  |
| 6–7<br>-                     | This field is reserved. Reserved                                     |  |  |  |
| 8<br>MCP_RSP_<br>CKSTP_P0_EN | Enable machine check to core 0 in response to check stop from core 1 |  |  |  |
| 9<br>MCP_RSP_<br>CKSTP_P1_EN | Enable machine check to core 1 in response to check stop from core 0 |  |  |  |
| 10–31<br>-                   | This field is reserved. Reserved                                     |  |  |  |

## 20.5.14 Automatic reset status register (GUTS\_AUTORSTSR)

Shown in the figure below, the AUTORSTSR contains the automatic reset status bits for core 0 and core 1.







#### **GUTS\_AUTORSTSR** field descriptions

| Field        | Description                                |  |
|--------------|--------------------------------------------|--|
| 0            | Core 0 was reset in response to check stop |  |
| RST_CKSTP_P0 |                                            |  |
|              | 0 No reset                                 |  |
|              | 1 Reset occurred.                          |  |
| 1            | Core 1 was reset in response to check stop |  |
| RST_CKSTP_P1 |                                            |  |
|              | 0 No reset                                 |  |
|              | 1 Reset occurred.                          |  |

Table continues on the next page...

## **GUTS\_AUTORSTSR** field descriptions (continued)

| Field             | Description                                                                                                                            |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2–7<br>-          | This field is reserved. Reserved                                                                                                       |  |  |
| 8<br>RST_MPIC_P0  | Core 0 was reset in response to MPIC reset request  0 No reset  1 Reset occurred                                                       |  |  |
| 9<br>RST_MPIC_P1  | Core 1 was reset in response to MPIC reset request  0 No reset  1 Reset occurred                                                       |  |  |
| 10–11             | This field is reserved. Reserved                                                                                                       |  |  |
| 12<br>RST_CORE_P0 | Core 0 was reset in response to internal core request to reset itself by setting bit DBCR0[RST] register  0 No reset  1 Reset occurred |  |  |
| 13<br>RST_CORE_P1 | Core 1 was reset in response to internal core request to reset itself by setting bit DBCR0[RST] register  0 No reset  1 Reset occurred |  |  |
| 14–15<br>-        | This field is reserved. Reserved                                                                                                       |  |  |
| 16<br>READY_P0    | Core 0 ready pin. This bit reflects what is driven on the READY_P0 external signal.  0 Core 0 not ready 1 Core 0 ready                 |  |  |
| 17<br>READY_P1    | Core 1 ready pin. This bit reflects what is driven on the READY_P1 external signal.  0 Core 1 not ready 1 Core 1 ready                 |  |  |
| 18–31<br>-        | This field is reserved. Reserved                                                                                                       |  |  |

## 20.5.15 Processor version register (GUTS\_PVR)

Shown in the figure below, the PVR contains the e500 processor version number. It is a memory-mapped copy of the PVR in the e500 core (and is therefore accessible to external devices). Processor version register (PVR) and system version register (SVR), lists the complete values for the P1021.





#### GUTS\_PVR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                         |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–15<br>Version   | A 16-bit number that identifies the version of the processor. Different version numbers indicate major differences between processors, such as which optional facilities and instructions are supported. (See Processor version register (PVR) and system version register (SVR), for specific values.)                             |
| 16–31<br>Revision | A 16-bit number that distinguishes between implementations of the version. Different revision numbers indicate minor differences between processors having the same version number, such as clock rate and engineering change level. (See Processor version register (PVR) and system version register (SVR), for specific values.) |

## 20.5.16 System version register (GUTS\_SVR)

Shown in the figure below, the SVR contains the system version number for the P1021 implementation. This value can also be read though the SVR SPR of the e500 core. Processor version register (PVR) and system version register (SVR) lists the complete values for the P1021.

Address: E\_0000h base + A4h offset = E\_00A4h



### **GUTS\_SVR** field descriptions

| Field                                                   | Description                          |  |
|---------------------------------------------------------|--------------------------------------|--|
| 0–31 System version numbers for the P1021 system logic: |                                      |  |
|                                                         | 0x80E_C_01_10 P1021 with security    |  |
|                                                         | 0x80E_4_01_10 P1021 without security |  |
|                                                         | 0x80E_D_01_10 P1012 with security    |  |
|                                                         | 0x80E_5_01_10 P1012 without security |  |

## 20.5.17 Reset control register (GUTS\_RSTCR)

Shown in the figure below, the RSTCR contains the reset control bits.





#### **GUTS\_RSTCR** field descriptions

| Field            | Description                         |  |
|------------------|-------------------------------------|--|
| 0–29<br>-        | This field is reserved.<br>Reserved |  |
| 30<br>HRESET_REQ | Hardware reset request              |  |
| 31<br>-          | This field is reserved. Reserved    |  |

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

Address: E\_0000h base + C0h offset = E\_00C0h

0

0

0

Reset

#### I/O voltage select status register (GUTS IOVSELSR) 20.5.18

Shown in the figure below, the IOVSELSR contains voltage configuration status bits for the chip driver/receivers on the BVDD (local bus, CE\_PB12, CE\_PB13, CE\_PB8, CE\_PA15, CE\_PB29, CE\_PB30, CE\_PB31, CE\_PC0), CVDD (eSDHC, eSPI, USB), and LVDD (eTSEC1, eTSEC2, eTSEC3) power planes. Voltage selection is achieved by tying the associated dedicated configuration inputs: LVDD\_VSEL, BVDD\_VSEL[0:1], and CVDD\_VSEL[0:1] appropriately.



0

0

0

0

0

0

0

0

0

0

| GUIS_ | IOVSEL | SR field | description | IS |
|-------|--------|----------|-------------|----|
|       |        |          |             |    |

0

| Field          | Description                                                                                                                                                                                  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–21<br>-      | This field is reserved. Reserved                                                                                                                                                             |  |  |
| 22–23<br>CVDDV | Selects the I/O voltage for the Secure Digital Bus, eSPI, and USB on the CVDD supply.  00 3.3 V (Default)  01 2.5 V  10 1.8 V  11 Reserved                                                   |  |  |
| 24–25<br>-     | This field is reserved. Reserved                                                                                                                                                             |  |  |
| 26–27<br>BVDDV | Selects the I/O voltage for the local bus and CE_PB12, CE_PB13, CE_PB8, CE_PA15, CE_PB29, CE_PB30, CE_PB31, and CE_PC0 on the BVDD supply.  00 3.3 V (default) 01 2.5 V 10 1.8 V 11 Reserved |  |  |
| 28–29<br>-     | This field is reserved. Reserved                                                                                                                                                             |  |  |
| 30–31<br>LVDDV |                                                                                                                                                                                              |  |  |

Table continues on the next page...

#### **GUTS\_IOVSELSR** field descriptions (continued)

| Field |    | Description     |  |  |
|-------|----|-----------------|--|--|
|       | 00 | 3.3 V (default) |  |  |
|       | 01 | 2.5 V           |  |  |
|       | 10 | Reserved        |  |  |
|       | 11 | Reserved        |  |  |

## 20.5.19 Open drain register (GUTS\_CPODRn)

There are three I/O ports, A to C. All pins on all ports are bidirectional and the pin values may be read while the pin is connected to an on-chip peripheral. In addition to this, each pin may be configured as a genera-purpose I/O signal or as a dedicated peripheral interface signal.

For each pin for each port, there is one bit that describes the open drain configuration. The value of the control bit determines whether the corresponding pin is actively driven as an output or is an open-drain driver. For ports with less than 32 pins, only the relevant bits are used.





#### GUTS\_CPODRn field descriptions

| Field       | Description                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>ODn | Open-drain configuration. Determines whether the corresponding pin is actively driven as an output or is an open-drain driver.                                                           |
|             | <ul> <li>The I/O pin is actively driven as an output.</li> <li>The I/O pin is an open-drain driver. As an output, the pin is driven active-low; otherwise it is three-stated.</li> </ul> |

## 20.5.20 Data register (GUTS\_CPDATn)

There is one bit per pin for each port. When the CPDATA register is read, it returns the data at the pin independent of whether the pin was defined as an input or output.

#### **GUTS Memory Map/Register Definition**

A write to CPDAT is latched. If the corresponding CPDIR bits have configured the port pin as an output, the latched value is driven onto the respective pin. However, if the corresponding CPDIR bits have configured the port pin as an input the latched value is prevented from reaching the pin. CPDAT may be read or written to at any time and is not initialized. For ports with less than 32 pins, only the relevant bits are used.



#### GUTS\_CPDATn field descriptions

| Field      | Description                            |
|------------|----------------------------------------|
| 0–31<br>Dn | Contains data for the respective port. |

## 20.5.21 Direction register (GUTS\_CPDIR1n)

These registers, shown in the figure below, describe the I/O direction of the CE\_PA, CE\_PB, and CE\_PC ports. CPDIR1A, CPDIR1B, and CPDIR1C are used for configuring CE\_PA[0:15], CE\_PB[0:15], and CE\_PC[0:15], respectively. CPDIR2A, CPDIR2B, and CPDIR2C are used for configuring CE\_PA[16:31], CE\_PB[16:31], and CE\_PC[16:31], respectively. For ports with less than 32 pins, only the relevant bits are used.



#### GUTS\_CPDIR1n field descriptions

| Field                                                     | Description         |  |
|-----------------------------------------------------------|---------------------|--|
| 0–31 Determines the I/O characteristics of pin <i>n</i> . |                     |  |
|                                                           | 00 Disabled         |  |
|                                                           | 01 Output Only      |  |
|                                                           | 10 Input Only       |  |
|                                                           | 11 Input and Output |  |

## 20.5.22 Direction register (GUTS\_CPDIR2n)

These registers, shown in the figure below, describe the I/O direction of the CE\_PA, CE\_PB, and CE\_PC ports. CPDIR1A, CPDIR1B, and CPDIR1C are used for configuring CE\_PA[0:15], CE\_PB[0:15], and CE\_PC[0:15], respectively. CPDIR2A, CPDIR2B, and CPDIR2C are used for configuring CE\_PA[16:31], CE\_PB[16:31], and CE\_PC[16:31], respectively. For ports with less than 32 pins, only the relevant bits are used.



#### GUTS\_CPDIR2n field descriptions

| Field        | Description                                     |
|--------------|-------------------------------------------------|
| 0–31<br>DIRn | Determines the I/O characteristics of pin $n$ . |
|              | 00 Disabled<br>01 Output Only                   |
|              | 10 Input Only 11 Input and Output               |

## 20.5.23 Pin assignment register (GUTS\_CPPAR1n)

These registers, shown in the figure below, are used to select the alternate functionality for the CE\_PA[0:31], CE\_PB[0:31], and CE\_PC[0:31] ports. Depending on the alternate functionality selected, these bits need to be configured as described in the table below. CPPAR1A, CPPAR1B, and CPPAR1C are used for configuring CE\_PA[0:15], CE\_PB[0:15], and CE\_PC[0:15], respectively. CPPAR2A, CPPAR2B, and CPPAR2C are used for configuring CE\_PA[16:31], CE\_PB[16:31], and CE\_PC[16:31], respectively. For ports with less than 32 pins, only the relevant bits are used.



#### GUTS\_CPPAR1n field descriptions

| Field | Description                                                                                      |  |
|-------|--------------------------------------------------------------------------------------------------|--|
| 0–31  | Determines the function of Pin $n$ .                                                             |  |
| SELn  | The settings select values from one of the columns of the appropriate port table in Ports Tables |  |
|       | 00 Selects functionality in column FUNC0 .                                                       |  |
|       | 01 Selects functionality in column FUNC1 .                                                       |  |
|       | 10 Selects functionality in column FUNC2 .                                                       |  |
|       | 11 Selects functionality in column FUNC3 .                                                       |  |

## 20.5.24 Pin assignment register (GUTS\_CPPAR2n)

These registers, shown in the figure below, are used to select the alternate functionality for the CE\_PA[0:31], CE\_PB[0:31], and CE\_PC[0:31] ports. Depending on the alternate functionality selected, these bits need to be configured as described in the table below. CPPAR1A, CPPAR1B, and CPPAR1C are used for configuring CE\_PA[0:15], CE\_PB[0:15], and CE\_PC[0:15], respectively. CPPAR2A, CPPAR2B, and CPPAR2C are used for configuring CE\_PA[16:31], CE\_PB[16:31], and CE\_PC[16:31], respectively. For ports with less than 32 pins, only the relevant bits are used.





#### **GUTS\_CPPAR2n** field descriptions

| Field | Description                                                                                      |  |
|-------|--------------------------------------------------------------------------------------------------|--|
| 0–31  | Determines the function of Pin $n$ .                                                             |  |
| SELn  | The settings select values from one of the columns of the appropriate port table in Ports Tables |  |
|       | 00 Selects functionality in column FUNC0 .                                                       |  |
|       | 01 Selects functionality in column FUNC1 .                                                       |  |
|       | 10 Selects functionality in column FUNC2 .                                                       |  |
|       | 11 Selects functionality in column FUNC3 .                                                       |  |

# 20.5.25 CE Interrupt multiplexing control register n (GUTS\_CEIMXCRn)

This register programs the routing of the interrupt signals from hardware accelerators in the P1021 to the QUICC Engine EXT[1..4] SNUMs. Refer to the "External Hardware Request" section of the "Configuration" chapter in the *QUICC Engine Block Reference Manual with Protocol Interworking* (QEIWRM). Interrupt signal connections can be routed either to the programmable interrupt controller (PIC) or to the QUICC Engine block. Routing to the QUICC Engine block allows it to handle the interrupts, which frees up the CPU.

Contact Freescale for the availability of microcode packages taking advantage of this feature. Note that the interrupt to the host CPU should be masked consistently with the programming of this register.



#### **GUTS\_CEIMXCR***n* field descriptions

| Field            | Description                   |                      |
|------------------|-------------------------------|----------------------|
| 0–26<br>-        | This field is res<br>Reserved | served.              |
| 27–31<br>CE_INT_ | QUICC Engine                  | interrupt selection. |
| SEL[0:4]         | 00000                         | EXTx                 |
|                  | 00001                         | Security_2           |
|                  | 00010                         | Security_1           |
|                  | 00011                         | IRQ_OUT_B            |
|                  | 00100-11111                   | Reserved             |

## 20.5.26 CE Interrupt mask register (GUTS\_CEIMXMASK)

This register programs the routing of the interrupt signals from hardware accelerators in the P1021 to the QUICC Engine EV\_Threads SNUMs. Refer to "External Hardware Request" section of the "Configuration" chapter in the QUICC Engine Block Reference Manual with Protocol Interworking (QEIWRM). Interrupt signal connections can be routed either to the programmable interrupt controller (PIC) or to the QUICC Engine block. Routing to the QUICC Engine block allows it to handle the interrupts, which frees up the CPU.

#### **GUTS Memory Map/Register Definition**

Contact Freescale for the availability of microcode packages taking advantage of this feature. Note that the interrupt to the host CPU should be masked consistently with the programming of this register.

Shown in the figure below, the CEIMXMASK contains bits that allow the masking of platform interrupts served by the QUICC Engine block.



#### **GUTS\_CEIMXMASK** field descriptions

| Field      | Description                        |  |
|------------|------------------------------------|--|
| 0          | For all bits:                      |  |
| security_2 |                                    |  |
|            | 0 Interrupt to the RISC is masked  |  |
|            | 1 Interrupt to the RISC is enabled |  |
| 1          | For all bits:                      |  |
| security_1 |                                    |  |
|            | 0 Interrupt to the RISC is masked  |  |
|            | 1 Interrupt to the RISC is enabled |  |
| 2          | For all bits:                      |  |
| IRQ_OUT_B  |                                    |  |
|            | 0 Interrupt to the RISC is masked  |  |
|            | 1 Interrupt to the RISC is enabled |  |
| 3–31       | This field is reserved.            |  |
| -          | Reserved                           |  |

## 20.5.27 CE Interrupt polarity register (GUTS\_CEIMXPOLAR)

Shown in the figure below, the CEIMXPOLAR selects the polarity for platform interrupts served by the QUICC Engine block.

Address: E\_0000h base + 214h offset = E\_0214h



#### **GUTS\_CEIMXPOLAR** field descriptions

| Field             | Description                                       |  |
|-------------------|---------------------------------------------------|--|
| 0–2<br>QEINTPOLAR | QUICC Engine interrupt polarity.                  |  |
|                   | 0 Interrupt is enabled when signal is active high |  |
|                   | 1 Interrupt is enabled when signal is active low  |  |
| 3–31<br>-         | This field is reserved. Reserved                  |  |

## 20.5.28 DDR clock disable register (GUTS\_DDRCLKDR)

Shown in the figure below, the DDRCLKDR contains bits that allow disabling the clocks of the DDR SDRAM controller.



#### **GUTS\_DDRCLKDR** field descriptions

| Field            | Description                                                           |  |
|------------------|-----------------------------------------------------------------------|--|
| 0–15             | This field is reserved.                                               |  |
| -                | Reserved.                                                             |  |
| 16–17<br>DDR_DIV | DDR controller complex clock divided by 2 or 4 to generate bus clock. |  |
|                  | 00 Divided by 2                                                       |  |
|                  | 01 Divided by 4                                                       |  |
|                  | 10 Reserved                                                           |  |
|                  | 11 Reserved                                                           |  |
| 18–25            | This field is reserved.                                               |  |
| -                | Reserved                                                              |  |
| 26               | DDR controller clock 0 disable                                        |  |
| DDR_MCK0_DIS     |                                                                       |  |
|                  | 0 MCK0 is enabled.                                                    |  |
|                  | 1 MCK0 is disabled.                                                   |  |
| 27               | DDR controller clock 1 disable                                        |  |
| DDR_MCK1_DIS     | 0 MCK1 is enabled.                                                    |  |
|                  | 1 MCK1 is disabled.                                                   |  |
|                  |                                                                       |  |
| 28               | DDR controller clock 2 disable                                        |  |
| DDR_MCK2_DIS     |                                                                       |  |

Table continues on the next page...

### **GUTS\_DDRCLKDR** field descriptions (continued)

| Field        | Description                    |  |
|--------------|--------------------------------|--|
|              | 0 MCK2 is enabled.             |  |
|              | 1 MCK2 is disabled.            |  |
| 29           | DDR controller clock 3 disable |  |
| DDR_MCK3_DIS |                                |  |
|              | 0 MCK3 is enabled.             |  |
|              | 1 MCK3 is disabled.            |  |
| 30–31        | This field is reserved.        |  |
| -            | Reserved                       |  |

## 20.5.29 Clock out control register (GUTS\_CLKOCR)

Shown in the figure below, the CLKOCR contains control bits that select the clock sources to be placed on the clock out (CLK\_OUT) signal.

Address: E\_0000h base + E00h offset = E\_0E00h



#### **GUTS\_CLKOCR** field descriptions

| Field   | Description                                                 |
|---------|-------------------------------------------------------------|
| 0       | Clock out enable.                                           |
| ENB     | 0 CLK_OUT signal is three-stated.                           |
|         | CLK_OUT signal is driven according to CLKOCR[CLK_SEL].      |
| 1–25    | This field is reserved.                                     |
| -       | Reserved                                                    |
| 26–31   | Clock out select                                            |
| CLK_SEL | All other bits not shown are Reserved                       |
|         | 000000 CCB (platform) clock                                 |
|         | 000001 CCB (platform) clock divided by 2                    |
|         | 000010 SYSCLK (echoes SYSCLK input)                         |
|         | 000011 SYSCLK divided by 2 (demonstrates platform PLL lock) |

## 20.5.30 ECM control register (GUTS\_ECMCR)

The ECMCR contains the four uppermost bits of the USB and eSDHC address bus for transactions initiated by these blocks.

Address: E\_0000h base + E20h offset = E\_0E20h



#### **GUTS\_ECMCR** field descriptions

| Field                   | Description                                                                              |
|-------------------------|------------------------------------------------------------------------------------------|
| 0–3<br>USB_UPRADR       | The uppermost bits of the USB address bus for all transactions initiated by the USB.     |
| 4–7<br>ESDHC_<br>UPRADR | The uppermost bits of the ESDHC address bus for all transactions initiated by the ESDHC. |
| 8–31<br>-               | This field is reserved. Reserved                                                         |

13

14

15

## 20.5.31 SRDS Control Register 0 (GUTS\_SRDSCR0)

The SRDS control register 0, as shown in the figure below, contains the functional control bits for the SerDes logic.





**GUTS\_SRDSCR0** field descriptions

| Field          | Description                                                                                                                                              |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>-      | This field is reserved. Reserved                                                                                                                         |
| 17-19<br>TXEQ0 | Transmit equalization selection bus for lane 0. Sets the peak value for output swing of transmitters and the amount of transmit equalization for lane 0. |
|                | Recommended setting per protocol:                                                                                                                        |
|                | <ul><li>PCI Express: 100</li><li>SGMII: 100</li></ul>                                                                                                    |
|                | 000 No equalization                                                                                                                                      |
|                | 001 1.09 x relative amplitude                                                                                                                            |
|                | 010 1.2 x relative amplitude                                                                                                                             |
|                | 011 1.33 x relative amplitude                                                                                                                            |
|                | 100 1.5 x relative amplitude                                                                                                                             |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **GUTS Memory Map/Register Definition**

## **GUTS\_SRDSCR0** field descriptions (continued)

| Field          | Description                                                                                                                                                   |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                | 101 1.71 x relative amplitude                                                                                                                                 |  |
|                | 110 2.0 x relative amplitude                                                                                                                                  |  |
|                | 111 Reserved                                                                                                                                                  |  |
| 20<br>-        | This field is reserved. Reserved                                                                                                                              |  |
| 21–23<br>TXEQ1 | Transmit equalization selection bus for lane 1. Sets the peak value for output swing of transmitters and the amount of transmit equalization for lane 1.      |  |
|                | Recommended setting per protocol:                                                                                                                             |  |
|                | <ul><li>PCI Express: 100</li><li>SGMII: 100</li></ul>                                                                                                         |  |
|                | 000 No equalization                                                                                                                                           |  |
|                | 001 1.09 x relative amplitude                                                                                                                                 |  |
|                | 010 1.2 x relative amplitude                                                                                                                                  |  |
|                | 011 1.33 x relative amplitude                                                                                                                                 |  |
|                | 100 1.5 x relative amplitude                                                                                                                                  |  |
|                | 101 1.71 x relative amplitude                                                                                                                                 |  |
|                | 110 2.0 x relative amplitude                                                                                                                                  |  |
|                | 111 Reserved                                                                                                                                                  |  |
| 24<br>SDPD     | SerDes power down. This power down signal shuts down the PLL, all of the receiver amplifiers, all of the samplers and places the transmitters in three-state. |  |
|                | Recommended setting: 0                                                                                                                                        |  |
|                | 0 Application mode                                                                                                                                            |  |
|                | 1 Block power down                                                                                                                                            |  |
| 25–31<br>-     | This field is reserved. Reserved                                                                                                                              |  |

## 20.5.32 SRDS Control Register 1 (GUTS\_SRDSCR1)

Shown in the figure below, the SRDSCR1 contains the functional control bits for the SerDes logic.





**GUTS\_SRDSCR1** field descriptions

| Field          | Description                                                                                                                                              |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–16<br>-      | This field is reserved. Reserved                                                                                                                         |
| 17–19<br>TXEQ2 | Transmit equalization selection bus for lane 2. Sets the peak value for output swing of transmitters and the amount of transmit equalization for lane 2. |
|                | Recommended setting per protocol:                                                                                                                        |
|                | <ul><li>PCI Express: 100</li><li>SGMII: 100</li></ul>                                                                                                    |
|                | 000 No equalization                                                                                                                                      |
|                | 001 1.09 x relative amplitude                                                                                                                            |
|                | 010 1.2 x relative amplitude                                                                                                                             |
|                | 011 1.33 x relative amplitude                                                                                                                            |
|                | 100 1.5 x relative amplitude                                                                                                                             |

Table continues on the next page...

#### **GUTS Memory Map/Register Definition**

#### **GUTS\_SRDSCR1** field descriptions (continued)

| Field          | Description                                                                                                                                              |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 101 1.71 x relative amplitude                                                                                                                            |
|                | 110 2.0 x relative amplitude                                                                                                                             |
|                | 111 Reserved                                                                                                                                             |
| 20<br>-        | This field is reserved. Reserved                                                                                                                         |
| 21–23<br>TXEQ3 | Transmit equalization selection bus for lane 3. Sets the peak value for output swing of transmitters and the amount of transmit equalization for lane 3. |
|                | Recommended setting per protocol:                                                                                                                        |
|                | PCI Express: 100                                                                                                                                         |
|                | SGMII: 100                                                                                                                                               |
|                | 000 No equalization                                                                                                                                      |
|                | 001 1.09 x relative amplitude                                                                                                                            |
|                | 010 1.2 x relative amplitude                                                                                                                             |
|                | 011 1.33 x relative amplitude                                                                                                                            |
|                | 100 1.5 x relative amplitude                                                                                                                             |
|                | 101 1.71 x relative amplitude                                                                                                                            |
|                | 110 2.0 x relative amplitude                                                                                                                             |
|                | 111 Reserved                                                                                                                                             |
| 24–31<br>-     | This field is reserved. Reserved                                                                                                                         |

## 20.5.33 SRDS Control Register 2 (GUTS\_SRDSCR2)

Shown in the figure below, the SRDSCR2 contains the functional control bits for the SerDes logic. Individual lanes can be powered down using SRDSCR2[0:7]. It requires the entire SerDes to reset in order to activate a lane from powerdown.





## **GUTS\_SRDSCR2** field descriptions

| Field      | Description                                                                                                         |
|------------|---------------------------------------------------------------------------------------------------------------------|
| 0<br>PD0   | Lane 0 power down  0 Normal  1 Power down Lane 0                                                                    |
| 1<br>PD1   | Lane 1 power down  0 Normal  1 Power down Lane 1                                                                    |
| 2–3        | This field is reserved. Reserved                                                                                    |
| 4<br>PD2   | Lane 2 power down  0 Normal  1 Power down Lane 2                                                                    |
| 5<br>PD3   | Lane 3 power down  0 Normal  1 Power down Lane 3                                                                    |
| 6–9<br>-   | This field is reserved. Reserved                                                                                    |
| 10<br>X3S0 | Lane 0 transmitter three-state  0 Normal  1 The transmitter output is disabled and place in a three-state condition |
| 11<br>X3S1 | Lane 1 transmitter three-state  0 Normal  1 The transmitter output is disabled and place in a three-state condition |
| 12–13      | This field is reserved. Reserved                                                                                    |
| 14<br>X3S2 | Lane 2 transmitter three-state  0 Normal  1 The transmitter output is disabled and place in a three-state condition |
| 15<br>X3S3 | Lane 3 transmitter three-state  0 Normal  1 The transmitter output is disabled and place in a three-state condition |
| 16–31<br>- | This field is reserved. Reserved                                                                                    |

## 20.5.34 SRDS Control Register 3 (GUTS\_SRDSCR3)

Show in the figure below, the SRDSCR3 contains the functional control bits used for the SerDes logic.





#### **GUTS\_SRDSCR3** field descriptions

| Field     | Description                                                                                                                                                                                          |  |  |  |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0<br>RPT0 | To enable repeater mode on Lane 0. Enables data received on serial inputs to be repeated back through to the transmitter outputs after data sampling and transition recovery on Lane 0.              |  |  |  |  |  |
|           | NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock must be from a common source.                                                                                 |  |  |  |  |  |
|           | NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, the P1012 SerDes and the SerDes of the switch on the other side should be fed from the same clock source. |  |  |  |  |  |
|           | 0 Repeater mode disabled                                                                                                                                                                             |  |  |  |  |  |
|           | 1 Enable repeater mode on Lane 0                                                                                                                                                                     |  |  |  |  |  |
| 1<br>RPT1 | To enable repeater mode on Lane 1. Enables data received on serial inputs to be repeated back through to the transmitter outputs after data sampling and transition recovery on Lane 1.              |  |  |  |  |  |
|           | NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock must be from a common source.                                                                                 |  |  |  |  |  |
|           | NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, the P1012 SerDes and the SerDes of the switch on the other side should be fed from the same clock source. |  |  |  |  |  |
|           | 0 Repeater mode disabled                                                                                                                                                                             |  |  |  |  |  |
|           | 1 Enable repeater mode on Lane 1                                                                                                                                                                     |  |  |  |  |  |
| 2<br>RPT2 | To enable repeater mode on Lane 2. Enables data received on serial inputs to be repeated back through to the transmitter outputs after data sampling and transition recovery on Lane 2.              |  |  |  |  |  |

Table continues on the next page...

## **GUTS\_SRDSCR3** field descriptions (continued)

| NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock refrom a common source.  NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, serDes and the SerDes of the switch on the other side should be fed from the same of the same of the serDes and the SerDes of the switch on the other side should be fed from the same of t | the P1012<br>lock source.<br>Ek through<br>must be<br>the P1012 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| SerDes and the SerDes of the switch on the other side should be fed from the same of the s | ck through must be the P1012                                    |
| 1 Enable repeater mode on Lane 2  To enable repeater mode on Lane 3. Enables data received on serial inputs to be repeated back to the transmitter outputs after data sampling and transition recovery on Lane 3.  NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock in from a common source.  NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, if SerDes and the SerDes of the switch on the other side should be fed from the same of the same of the served on Lane 3.  4–5  This field is reserved. Reserved  This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | must be<br>the P1012                                            |
| To enable repeater mode on Lane 3. Enables data received on serial inputs to be repeated back to the transmitter outputs after data sampling and transition recovery on Lane 3.  NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock refrom a common source.  NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, and SerDes and the SerDes of the switch on the other side should be fed from the same of the same of the served of the served.  This field is reserved.  Reserved  This field is reserved.  Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | must be the P1012                                               |
| to the transmitter outputs after data sampling and transition recovery on Lane 3.  NOTE: When SerDes repeater mode is enabled, the SerDes refclk and Rx data source clock refrom a common source.  NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, so SerDes and the SerDes of the switch on the other side should be fed from the same of the same of the served are repeater mode on Lane 3.  4–5 This field is reserved. Reserved  This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | must be the P1012                                               |
| from a common source.  NOTE: The repeater mode does not support frequency offset. If repeater mode is to be used, so SerDes and the SerDes of the switch on the other side should be fed from the same of the same of the served of the switch on the other side should be fed from the same of the same of the served of the switch on the other side should be fed from the same of the same of the same of the same of the served of the switch on the other side should be fed from the same of th | the P1012                                                       |
| SerDes and the SerDes of the switch on the other side should be fed from the same cl  0 Repeater mode disabled 1 Enable repeater mode on Lane 3  4–5 This field is reserved. Reserved  6–13 This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                 |
| 1 Enable repeater mode on Lane 3  4–5 This field is reserved. Reserved  6–13 This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                 |
| 4–5 This field is reserved Reserved  6–13 This field is reserved Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                 |
| - Reserved 6–13 This field is reserved Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                 |
| - Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                 |
| Transmitter impedance calibration stop command. Allows user to stop calibration of transmitter impedances.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                 |
| Recommended setting per protocol:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                 |
| <ul><li>PCI Express: 0</li><li>SGMII: 0</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                 |
| 0 Run transmit impedance calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                 |
| 1 Stop transmit impedance calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                 |
| 15 Receiver impedance calibration stop command. Allows user to stop calibration of receiver impe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | dances.                                                         |
| RIMPCALS Recommended setting per protocol:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                 |
| <ul><li>PCI Express: 0</li><li>SGMII: 0</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                 |
| 0 Run receive impedance calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                 |
| 1 Stop receive impedance calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                 |
| 16–18 This field is reserved Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                 |
| 19–23 Recommended setting per protocol:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                 |
| NOTE: If this lane is used for PCI Express protocol per I/O Port Selection, to ensure successful training and correct functionality, this bit field must be set to 10011, which is different for reset default value of 10000. This can be achieved by adding the required register comprocedure at the early stage of the device initialization code right after the HRESET_B assertion such that the correct link training can take place. A delay of 100 ms between and the code of checking LTSSM = 0x16 is required to verify a successful link up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rom the<br>figuration<br>de-                                    |
| Receiver electrical idle detection control for Lane 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | l                                                               |

Table continues on the next page...

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## **GUTS\_SRDSCR3** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 000 Loss of signal detect function is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 001 Default SGMII levels (low = 30 mV, high = 100 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 010 Intermediate level (low = 38 mV, high = 120 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 011 Intermediate level (low = 50 mV, high = 150 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 100 Default PCI Express levels (low = 65 mV, high = 175mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 101 Low = 75 mV, high = 200 mV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 110 Intermediate level (low = 88 mV, high = 225 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 111 Intermediate level (low = 100 mV, high = 250mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | PCI Express receiver electrical idle detection control for Lane 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | 00 Exit from idle ≈88 UI and unexpected idle detect ≈1 µs (application mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|               | 01 Exit from idle ≈88 UI and unexpected idle detect ≈10 µs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 10 Exit from idle ≈48 UI and unexpected idle detect ≈1 µs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | 11 Bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 24–26<br>-    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 27–31<br>EIC1 | Recommended setting per protocol:  • PCI Express: 10011  • SGMII: 00100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | NOTE: If this lane is used for PCI Express protocol per I/O Port Selection, to ensure successful link training and correct functionality, this bit field must be set to 10011, which is different from the reset default value 10000. This can be achieved by adding the required register configuration procedure at the early stage of the device initialization code right after the HRESET_B deassertion such that the correct link training can take place. A delay of 100 ms between this code and the code of checking LTSSM = 0x16 to verify a successful link up. |
|               | Receiver electrical idle detection control for Lane 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 000 Loss of signal detect function is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 001 Default SGMII levels (low = 30 mV, high = 100 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | 010 Intermediate level (low = 38 mV, high = 120 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 011 Intermediate level (low = 50 mV, high = 150 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 100 Default PCI Express levels (low = 65 mV, high = 175 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 101 Low = 75 mV, high = 200 mV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 110 Intermediate level (low = 88 mV, high = 225 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 111 Intermediate level (low = 100 mV, high = 250 mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | PCI Express receiver electrical idle detection control for Lane 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | 00) Exit from idle ≈88 UI and unexpected idle detect ≈1 µs (application mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | 01 Exit from idle ≈88 UI and unexpected idle detect ≈10 µs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | 10 Exit from idle ≈48 UI and unexpected idle detect ≈1 µs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | 11 Bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## 20.5.35 SRDS Control Register 4 (GUTS\_SRDSCR4)

Show in the figure below, the SRDSCR4 contains the functional control bits used for the SerDes logic.

Address: E\_0000h base + 3010h offset = E\_3010h



#### **GUTS\_SRDSCR4** field descriptions

| Field                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0–18<br>-                                    | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| 19–23                                        | Recommended Setting per protocol:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| EIC2                                         | PCI Express: 10011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|                                              | SGMII: 00100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|                                              | NOTE: If this lane is used for PCI Express protocol per I/O Port Selection, to ensure successful link training and correct functionality, this bit field must be set to 10011, which is different from the reset default value of 10000. This can be achieved by adding the required register configuration procedure at the early stage of the device initialization code right after the HRESET_B deassertion such that the correct link training can take place. A delay of 100 ms between this code and the code of checking LTSSM = 0x16 is required to verify a successful link up. |  |  |  |  |  |
|                                              | Receiver electrical idle detection control for Lane 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|                                              | 000 Loss of signal detect function is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                                              | 001 Default SGMII levels (Low=30mV, High=100mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                                              | 010 Intermediate level (Low=38mV, High=120mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                              | 011 Intermediate level (Low=50mV, High=150mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 100 Default PEX levels(Low=65mV, High=175mV) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                                              | 101 Low=75mV, High=200mV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                              | 110 Intermediate level (Low=88mV, High=225mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                              | 111 Intermediate level (Low=100mV, High=250mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                                              | PCI-EXP receiver electrical idle detection control for Lane 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                                              | 00 Exit from Idle ~88UI and Unexpected Idle Detect ~1us(Application Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                                              | 01 Exit from Idle ~88UI and Unexpected Idle Detect ~10us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                              | 10 Exit from Idle ~48UI and Unexpected Idle Detect ~1us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| 04.00                                        | 11 Bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 24–26<br>-                                   | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |

Table continues on the next page...

#### **GUTS\_SRDSCR4** field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 27–31 | Recommended Setting per protocol:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| EIC3  | PCI Express: 10011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|       | SGMII: 00100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|       | NOTE: If this lane is used for PCI Express protocol per I/O Port Selection, to ensure successful link training and correct functionality, this bit field must be set to 10011, which is different from the reset default value 10000. This can be achieved by adding the required register configuration procedure at the early stage of the device initialization code right after the HRESET_B deassertion such that the correct link training can take place. A delay of 100 ms between this code and the code of checking LTSSM = 0x16 to verify a successful link up. |  |  |  |  |  |
|       | Receiver electrical idle detection control for Lane 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|       | 000 Loss of signal detect function is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|       | 001 Default SGMII levels (Low=30mV, High=100mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|       | 010 Intermediate level (Low=38mV, High=120mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | 011 Intermediate level (Low=50mV, High=150mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | 100 Default PEX levels(Low=65mV, High=175mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|       | 101 Low=75mV, High=200mV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|       | 110 Intermediate level (Low=88mV, High=225mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | 111 Intermediate level (Low=100mV, High=250mV)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|       | PCI-EXP receiver electrical idle detection control for Lane 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|       | 00 Exit from Idle ~88UI and Unexpected Idle Detect ~1us (Application Mode) 01 Exit from Idle ~88UI and Unexpected Idle Detect ~10us 10 Exit from Idle ~48UI and Unexpected Idle Detect ~1us 11 Bypass                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |

## 20.6 Functional description

This section describes the global utilities from a functional perspective.

### 20.6.1 Power management

The P1021 has features to minimize power consumption at several levels.

Dynamic power management locally minimizes power consumption when a block is idle. Software can also shut down clocks to individual blocks when they are not needed through a memory-mapped register (DEVDISR). Additionally, software running on the e500 cores can access the cores's SPRs to put the device into doze or nap power down state. Finally, software can access a memory-mapped register (POWMGTCR) in the global utilities block to put the device in the doze or sleep states.

Note that the software that writes to either DEVDISR or POWMGTCR can be running either on the e500 cores or on an external master that can write to the P1021 memory-mapped registers through the PCI Express interfaces.

These features are described in further detail in this section.

## 20.6.1.1 Relationship between both cores and device power management states

The P1021 has three low-power states: doze, nap, and sleep.

The mapping of both cores and device power management states is shown in Figure 20-58 showing state transitions from the perspective of the e500 cores.



Figure 20-58. e500 Cores Power Management State Diagram

For each operating state represented in the diagram, the cores's state is listed first, with the corresponding state of the device shown beneath it in parenthesis. Note that there are many other variables that control the state transitions between device power management states. These additional variables are described in more detail in Power-down sequence coordination.

Table 20-60 lists basic characteristics of the low-power modes and the full on mode.

Table 20-60. P1021 Power management modes basic description

| Mode    | Description                                                                                                                                 | Core Re | sponds To  | Signa                           | States   |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------|---------|------------|---------------------------------|----------|
|         |                                                                                                                                             | Snoop   | Interrupts | READY<br>_P0 or<br>READY<br>_P1 | ASLEEP   |
| Full On | All units operating normally.                                                                                                               | Yes     | Yes        | Asserted                        | Negated  |
| Doze0/1 | Core 0 or stops dispatching new instructions (core 0 or 1 is halted)                                                                        | Yes     | Yes        | Negated                         | Negated  |
| Nap0/1  | Core 0 or 1 is stopped with clocks off except to time base Should flush data cache before entering                                          | No      | Yes        | Negated                         | Negated  |
| Sleep   | Core is stopped with clocks off. Clocks powered down to all blocks (including core time base) except to the interrupt controller (PIC) unit | No      | Yes        | Negated                         | Asserted |

#### 20.6.1.2 CKSTP\_IN0/1\_B is not power management

CKSTP\_IN0/1\_B are not described here because they are not considered power management signals, although asserting these do stop the cores and a stopped core is technically in a low-power mode.

CKSTP\_IN0/1\_B are described in Detailed signal descriptions.

### 20.6.1.3 Dynamic power management

Many blocks in the P1021 can dynamically turn off clocks within the block when sections of the block are idle.

This feature is always enabled and occurs automatically.

#### 20.6.1.4 Shutting down unused blocks

As described in Device disable register (GUTS\_DEVDISR), DEVDISR provides a way to shut down certain functional blocks within the device when they are not needed in a particular system. DEVDISR can be written by the both e500 cores or by an external master. Powering down a block in this way turns off all clocks to that block.

DEVDISR was designed with the expectation that, once initialized by software, it would be modified only by a hard system reset (HRESET\_B). It is recommended that this register be written only during system initialization. Blocks disabled by DEVDISR must not be re-enabled without a hard reset. (Setting DEVDISR[TB0/1] disables the cores's timer facilities, and setting DEVDISR[E500\_CORE0/1] places the cores in the

core\_stopped state in which they do not respond to interrupts.) The results of re-enabling previously disabled blocks (by clearing the corresponding DEVDISR field) without a hard reset are boundedly undefined.

#### NOTE

Functional blocks disabled using DEVDISR cannot respond to configuration accesses. Any access to configuration, control, and status registers of a disabled block is a programming error.

### 20.6.1.5 Software-controlled power-down states

e500 software can place the device in doze or nap power-down states by writing to HID0 in the core.

In addition, external masters can write to the memory-mapped POWMGTCR in the P1021 to cause the device to enter doze or sleep modes.

#### 20.6.1.5.1 Doze mode

In doze mode, the given e500 core suspends instruction execution, significantly reducing the power consumption of the cores.

Snooping of the L1 data cache is still supported and thus the data in the data cache is kept coherent. Interrupts directed to the each core as described in Interrupts to the e500 processor core, are monitored by the device and cause the P1021 to use the defined handshake mechanism to exit the cores from doze mode to allow the cores to recognize and process the interrupt; however, unless the interrupt subroutine turns off (or masks) the control bits that enabled doze mode (MSR[WE], and HID0[DOZE]), the device reenters doze mode after the interrupt has been serviced. See Interrupts and power management, for more information.

The given e500 core's timer facilities are still enabled during doze mode, and core time base interrupts can be generated. All device logic external to the core remains fully operational in doze mode.

## 20.6.1.5.2 Nap mode

In nap mode all clocks internal to the e500 core are turned off except for their timer facilities clock (the core time base).

The L1 caches do not respond to snoops in nap mode, so if coherency with external I/O transactions is required, the L1 cache must be flushed before entering nap mode.

#### **Functional description**

Similar to doze mode, interrupts occurring in nap mode cause the device to wake up the e500 core in order to service the interrupt. However, unless the interrupt service routine changes the control bits that caused the device to enter nap mode (MSR[WE], and HID0[NAP]), the core returns to nap mode after the interrupt is serviced. See Interrupts and power management, for more information.

All device logic external to the e500 core remains fully operational in nap mode.

#### 20.6.1.5.3 Sleep mode

In sleep mode, all clocks internal to both e500 cores are turned off, including the timer facilities clock.

All I/O interfaces in the device logic are also shut down except for the three eTSECs. Only the clocks to the P1021 PIC and three eTSECs (if enabled in the PMCDR) are still running so that an external interrupt, ethernet magic packet, or the PIC Global Timer can wake up the device.

After the core and I/O interfaces have shut down, ASLEEP is asserted and READY\_P0 and READY\_P1 are negated.

#### NOTE

Internal interrupt sources like the core interval timer or watchdog timer depend on an active clock for their operation and these are disabled in sleep mode.

#### 20.6.1.6 Power management control fields

The e500 cores provide the following fields to signal power management requests to the device logic.

- MSR[WE]-Used to qualify the values of HID0[DOZE0/1, NAP] in the generation of the internal *doze* and *nap* signals.
- HID0[DOZE*n*]-Signals the device to initiate doze mode for the given core.
- HID0[NAP*n*]-Signals the device to initiate nap mode for the given core.

These register fields and their functional relationship are shown in Figure 20-59. The *PowerPC e500 Core Reference Manual* has details on accessing these power management control bits.

An external master can also initiate power management requests by setting the applicable DOZ or SLP bits in the memory-mapped power management control and status register (POWMGTCSR). Because the core responds to snoops while dozing but not while

napping, maintaining cache coherency requires significant preparation by the core before entering nap mode. For this reason only the core can initiate a nap during normal operation while other masters can initiate a doze.

#### 20.6.1.7 Power-down sequence coordination

To preserve cache coherency and otherwise avoid loss of system state, a core's transition to low-power modes is coordinated by a set of handshaking signals, shown in Figure 20-59, and protocols with all other P1021 functional blocks that respond to power-down requests. The mode-transition protocol is executed automatically under these conditions and is shown in Figure 20-58 and described in Table 20-61.

The column in Table 20-61 showing the global utilities block as initiating a low-power mode corresponds to the external masters that can write to the POWMGTCSR that resides in the global utilities block. For the P1021, these are the PCI Express interfaces. However, note that the core can also write to POWMGTCSR and, in this case, can initiate power management through the global utilities block.

Table 20-61. Power management entry protocol and initiating functional units

| Low-Power<br>Mode | <b>,</b>                                                                                                                                                                                                                  |                  | Initiating Functional<br>Unit |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------|--|--|
|                   |                                                                                                                                                                                                                           | Global Utilities | Core                          |  |  |
| Doze              | <ol> <li>Assert core0/1_halt input to core.</li> <li>Wait for core0/1_halted handshake from core.</li> </ol>                                                                                                              | 1                | 1                             |  |  |
| Nap               | Follow doze protocol     Assert core0/1_stop input to core.     Wait for core0/1_stopped handshake from core.                                                                                                             | -                | 1                             |  |  |
| Sleep             | Follow doze protocol; send stop requests to rest of device.     Follow nap protocol.     Wait for all interfaces to acknowledge stop requests.     Assert ASLEEP, negate READY, power down all clocks except to PIC unit. | 1                | -                             |  |  |

As shown in Figure 20-59, the e500 cores enter low-power modes only in response to the *core0/1\_halt*, *core0/1\_stop*, or *core0/1\_tben* inputs from the P1021 power management logic. These inputs may be prompted by the core (by setting the NAP0/1 or DOZE0/1 bits in the HID0 when enabled by setting MSR[WE]) or by an external master (by setting POWMGTCSR[DOZ0/1,SLP].

Figure 20-59 shows how all the clocking to the core timer facilities are disabled by clearing HID0[TB0/1EN]. When enabled, (HID0[TB0/1EN] = 1), the clock source is either the CCB clock divided by eight (the default) or a synchronized version of the RTC input. For more details, see Summary of core integration details.



Figure 20-59. P1021 power management handshaking signals

#### 20.6.1.8 Interrupts and power management

Whether low-power modes are automatically re-enabled after an interrupt is processed differs depending on whether the low power mode was entered due to a write to the core MSR[WE] bit or the low power mode was entered due to a write to POWMGTCSR.

#### 20.6.1.8.1 Interrupts and power management controlled by MSR[WE]

When an interrupt is asserted to the CPU, the core complex saves portions of the MSR to MCSRR1, CSRR1, or SRR1 (depending on the type of interrupt), and restores those values on return from the routine.

MSR[WE], which gates the *doze* and *nap* power management outputs (internal device signals) from the core complex, is always among the bits saved and restored; hence these outputs negate to the P1021 power management logic when the interrupt begins processing in the core. They return to their previous state when the core executes an **rfi**, **rfci**, or **rfmci** instruction. Interrupts to the e500 processor core, lists interrupts that cause the device to wake up.

#### NOTE

Returning *doze* and *nap* signals to their original state when MSR[WE] is restored differs from how power management is implemented on earlier PowerPC devices where MSR[POW], which enables power-down requests, is cleared when the processor exits a low-power state and is not automatically restored, as it is in implementations of the embedded category in the Power ISA.

### 20.6.1.8.2 Interrupts and power management controlled by POWMGTCSR

The IRQ\_MSK and CI\_MSK fields of the POWMGTCSR register prevent *int\_B* interrupts or *cint\_B* critical interrupts from waking the device from a low power state.

This is true regardless of the method used to enter the low power state.

Any unmasked interrupt (not masked by the mask bits in the POWMGTCSR register) causes the POWMGTCSR[DOZ0/1,SLP] fields to be cleared when it occurs. When such an interrupt occurs, the device returns to the normal operating mode and does not automatically attempt to return to a low power state after the interrupt is handled.

Note that interrupts caused by the unconditional debug event (UDE\_B) and machine check (MCP\_B) signals are not masked by the IRQ\_MSK and CI\_MSK fields; therefore, when these signals assert, the POWMGTCSR[DOZ0/1,SLP] fields are cleared and the

#### **Functional description**

device will return to full power operation. See Power management control and status register (GUTS\_POWMGTCSR), for detailed information about the bits of POWMGTCSR.

Note also that unmasked interrupts that occur while the device is in the process of going into the sleep state (before sleep is completely attained) can also cause the device to clear the POWMGTCSR[DOZ0/1,SLP] fields and return the device to full power operation.

### 20.6.1.9 Snooping in power down modes

When the device is in doze mode, the e500 core is in the core-halted state and it snoops its L1 caches and full coherency is maintained.

In deeper power-down modes, however, the e500 core does not respond to snoops.

The device does not perform dynamic bus snooping as described in the *e500 Reference Manual*. That is, when the e500 core is in the core-stopped state (which is the state of the core when the device is in either the nap or sleep state), the core is not awakened to perform snoops on global transactions. Therefore, before entering nap or sleep modes, the L1 caches should be flushed if coherency is required during these power-down modes.

### 20.6.1.10 Software considerations for power management

Setting MSR[WE] generates a request to the device logic (external to the core complex) to enter a power saving state.

It is assumed that the desired power-saving state (doze or nap) was set up by setting the appropriate HID0 bit, typically at system start-up time. Setting WE has no direct effect on instruction execution, but is reflected on the internal *doze* and *nap* signals, depending on the HID0 settings. To ensure a clean transition into and out of a power-saving mode, the following program sequence is recommended:

```
sync
mtmsr (WE)
isync
loop: br loop
```

### 20.6.1.11 Requirements for reaching and recovering from sleep state

In order to successfully reach the sleep state, I/O traffic to the device must be stopped.

The logic that controls the power down sequence waits for all I/O interfaces to become idle. In some applications this may happen eventually without actively shutting down interfaces, but most likely, software will have to take steps to shut down the eTSEC and PCI Express interfaces, among others, before issuing the command (either the write to the core MSR[WE] as described above or writing to POWMGTCSR) to put the device into sleep state.

**Functional description** 

# **Chapter 21 Debug Features and Watchpoint Facility**

This chapter describes all customer-visible debug modes of the SoC integrated device. The debug features on the chip pertain to the enhanced local bus controller (eLBC) and the DDR SDRAM interface.

#### 21.1 Introduction

This chapter describes all customer-visible debug modes of the P1021 integrated device.

The debug features on the P1021 pertain to the enhanced local bus controller (eLBC) and the DDR SDRAM interface. In addition to the external interfaces, the P1021 provides triggering capabilities based on user-programmable events. In addition, the watchpoint monitor and trace buffer provide some visibility into internal buses. This chapter also describes context ID registers, useful for software debug, and describes the JTAG access port signals that comply with the IEEE 1149.1 boundary-scan specification.

P1021 provides the following debug features:

- DDR SDRAM transactions (DDR SDRAM interface debug)
- eLBC transactions (Local bus interface debug)
- Watchpoint monitor and trace buffer (Watchpoint monitor and Trace buffer)

## 21.1.1 Overview

As shown in the figure below, debug information is provided through the LBC and DDR SDRAM interfaces. Limited visibility, through a 256 entry x 64-bit trace buffer, is also provided for the processor core interface.

This visibility into internal device operation is useful for debugging application software through inverse assembly and reconstruction of the fetch stream.

#### Introduction

The combination of a source ID (MSRCID[0:4]) and a data-valid signal (MDVAL) indicates that meaningful debug information is visible on either the local bus or DDR SDRAM interfaces. A logic analyzer can be programmed to capture data based on the values of MSRCID[0:4] and MDVAL, which supplement existing DDR and eLBC signals. Without MSRCID and MDVAL, it is not possible to provide a logic analyzer with the transaction source and validity information. It needs a trigger criteria to filter transactions of interest.



Figure 21-1. Debug and watchpoint monitor block diagram

Other system debugging is supported by the programmable triggering of the watchpoint monitor and trace buffer. Both can be triggered from one of the following three sources:

- Each other
- A performance monitor event
- An external source (through TRIG\_IN)

The watchpoint monitor can be configured to assert TRIG\_OUT when a programmed event occurs. The two context ID registers, described in Programmed context ID register (debug\_PCIDR), are useful for software debug.

#### **21.1.2 Features**

The principal features of the debug modes and the watchpoint monitor are as follows:

- eLBC and DDR interface source ID and data-valid indicators that can be selected as follows:
  - Both eLBC or DDR SDRAM source ID can be selected to be driven onto the dedicated MSRCID[0:4] pins
  - DDR SDRAM source ID and data-valid indicators can also be selected to be driven onto the error correcting code (ECC) pins of the DDR interface
- Watchpoint monitor that supports the following:
  - Two-level triggering
  - Programmable external trigger (TRIG\_OUT)
  - Interlock with performance monitor to use its large number of counters
- Trace buffer features that support the following:
  - Two-level triggering
  - Programmable external trigger (TRIG\_OUT)
  - Interlocked with performance monitor to use its large number of counters
  - 256-entry trace buffer, 64 bits each
  - Programmable trace start and stop
  - Ability to function as a second watchpoint monitor
- Context ID registers that can be programmed to trigger events

## 21.1.3 Modes of operation

The eLBC and DDR SDRAM interfaces all have debug modes, which are controlled by values on configuration inputs during the power-on reset (POR) sequence, as shown in the table below.

The DDR controller can also drive debug information on either MSRCID[0:4] or MECC[0:7]. See Source and target ID for additional information about the source ID information driven on the debug signals in these modes.

Note that both the watchpoint monitor and trace buffer also operate in a variety of modes.

Table 21-1. POR configuration settings and debug modes

| Configuration<br>Signal   | POR<br>Valu<br>e | /alu                                                                                                                         |                                 |  |  |
|---------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--|--|
| CFG_MEM_DEBUG             | 0                | Debug information from the eLBC is driven on the MSRCID and MDVAL signals                                                    | Memory                          |  |  |
| Default (1)               | 1                | Debug information from the DDR SDRAM controller is driven on the MSRCID and MDVAL signals (default).                         | debug mode<br>(eLBC and<br>DDR) |  |  |
| CFG_DDR_DEBUG Default (1) | 0                | Debug information is driven on the ECC pins instead of normal ECC I/O. ECC signals from memory devices must be disconnected. | DDR<br>SDRAM                    |  |  |
| ,                         | 1                | Debug information is not driven on ECC pins. ECC pins function in their normal mode (default).                               | interface<br>debug mode         |  |  |

## 21.1.3.1 Memory debug mode (eLBC and DDR)

Both the eLBC and the DDR SDRAM controllers can drive debug information (source ID and data-valid indicator) onto MSRCID[0:4] and MDVAL.

As shown in Table 21-1, the values of CFG\_MEM\_DEBUG control the multiplexing during POR. If CFG\_MEM\_DEBUG is low when sampled during POR, the eLBC SDRAM information appears on MSRCID[0:4] and MDVAL. If DMA\_DACK0\_B is high when sampled during POR, the debug information from the DDR SDRAM controller is presented on MSRCID[0:4] and MDVAL.

## 21.1.3.2 DDR SDRAM interface debug mode

CFG\_DDR\_DEBUG is sampled during POR to multiplex either ECC or debug information on the ECC pins of the DDR SDRAM interfaces.

As shown in Table 21-1, if CFG\_DDR\_DEBUG is low during POR, the ECC pins operate in debug mode and provide MSRCID and MDVAL information. CFG\_DDR\_DEBUG must be pulled low during POR to use the ECC pins in debug mode.

If CFG\_DDR\_DEBUG is unconnected, an internal pull-up resistor ensures the ECC pins always source DDR SDRAM error correcting code information as their default power-on reset configuration.

#### NOTE

If the DDR ECC pins are in debug mode (configured for debug during POR), ECC checking is disabled in the memory controller. In this case, MECC[0:4] do not provide ECC information and must not be connected to SDRAM devices.

P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## 21.1.3.3 Watchpoint monitor modes

The table below lists the operating modes supported by the watchpoint monitor.

Table 21-2. Watchpoint monitor modes

| Operating Mode                                 | Trigger Logic                                                                                                                                                                                                                                           |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Immediate trigger arming                       | The watchpoint monitor triggers as soon as the first trigger event occurs.                                                                                                                                                                              |
| (one-level triggering)                         |                                                                                                                                                                                                                                                         |
| Wait for trigger arming (two-level triggering) | The watchpoint monitor waits for a specific event before enabling (arming) the trigger logic. The monitor does not respond to trigger events until after the arming event occurs. This function is similar to two-level triggering on a logic analyzer. |
| Assert TRIG_OUT on hit                         | The debug logic can be programmed to assert the TRIG_OUT signal when a programmed watchpoint monitor event occurs. This signal can be used to trigger a logic analyzer.                                                                                 |

#### 21.1.3.4 Trace buffer modes

The table below lists the operating modes supported by trace buffer.

Table 21-3. Trace buffer modes

| Operating Mode               | Trigger Logic                                                                                                                                                  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Immediate trigger arming     | The trace buffer triggers as soon as the first trigger event occurs.                                                                                           |
| (one-level triggering)       |                                                                                                                                                                |
| Wait for trigger arming      | The trace buffer waits for a specific event before enabling (arming) the trigger logic. The                                                                    |
| (two-level triggering)       | trace buffer does not respond to trigger events until after the arming event occurs. This function is similar to two-level triggering on a logic analyzer.     |
| Specific interface selection | The trace buffer can be programmed to trace one of several internal interfaces.                                                                                |
| Specific event selection     | The trace buffer can be programmed to trace on the occurrence of one or several concurrent events.                                                             |
| Specific trace selection     | To facilitate trace data filtering, the trace buffer can be configured to capture data under the following conditions:                                         |
|                              | <ul> <li>On every cycle in which a valid transaction is present on the selected interface</li> <li>Only when the programmed trace event is detected</li> </ul> |
| Programmable trace stop      | The trace buffer may be programmed to stop tracing when a programmed stop-tracing event occurs or when the 256-entry buffer is full.                           |

## 21.2 Debug external signal description

This section provides information about all the external signals associated with the various P1021 debug functions.

As shown in Table 21-1, the P1021 has several signals that are sampled during POR to determine the configuration of the phase-locked loop clock mode and the ROM, flash, and dynamic memory. See Power-on reset configuration.

To facilitate system testing, the P1021 provides a JTAG test access port (TAP) that complies with the IEEE 1149.1 boundary-scan specification. This section also describes JTAG TAP signals.

## 21.2.1 Signals overview

Table 21-4 contains summaries of all signals associated with device debug features alongside a reference to the page containing further information. Table 21-5 provides the detailed descriptions about the signals. Some signals (the MECC bus for example) are described in other chapters, but are described here also for completeness. The descriptions in this chapter focus on the signals' debugging utility.

Table 21-4. Debug, watchpoint, and test signal summary

| Name        | Descriptio<br>n                 | Function al Block | Function                                                                                                                                                                                                                                         | Reset<br>Value | l/<br>O        | Page                             |
|-------------|---------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------------------------|
| MDVAL       | Memory<br>data-valid            | Debug             | Selectable data-valid signal from either DDR SDRAM controller or eLBC.                                                                                                                                                                           | 0              | 0              | Debug<br>signal<br>s-<br>details |
| MECC[0:7]   | DDR error<br>correcting<br>code | DDR<br>SDRAM      | In debug mode, the high-order six bits carry debug information (transaction source ID and data-valid indication).                                                                                                                                | 0x08           | O <sup>1</sup> | Debug<br>signal<br>s-<br>details |
| MSRCID[0:1] | Memory<br>source ID             | Debug             | Selectable transaction source ID from either DDR SDRAM controller or eLBC.                                                                                                                                                                       | Reset_cfg      | 0              | Debug<br>signal<br>s-<br>details |
| MSRCID[2:4] |                                 |                   |                                                                                                                                                                                                                                                  | 111            | 0              | Debug<br>signal<br>s-<br>details |
| TRIG_IN     | Trigger in                      | Debug             | Inbound trigger for various functions in the watchpoint monitor and trace buffer.                                                                                                                                                                | 1              | I              | Table<br>21-6                    |
| TRIG_OUT    | Trigger out                     | Debug             | Can be used externally for triggering a logic analyzer. Additionally, it can be used for observing system ready indication. Functions are multiplexed onto this signal depending on TOSR[SEL] (see Trigger output source register (debug_TOSR)). | 1              | Ο              | Table<br>21-6                    |

Table 21-4. Debug, watchpoint, and test signal summary (continued)

| Name            | Descriptio<br>n  | Function al Block | Function                                                                                                       | Reset<br>Value | l/<br>O | Page          |
|-----------------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------|----------------|---------|---------------|
| тск             | Test clock       | Debug             | Clock for JTAG testing.                                                                                        | 0              | I       | Table<br>21-7 |
| TDI             | Test data input  | Debug             | Serial input for instructions and data to the JTAG test subsystem. Internally pulled up.                       | 1              | I       | Table<br>21-7 |
| TDO             | Test data output | Debug             | Serial data output for the JTAG test subsystem. High impedance except when scanning out data.                  | Hi Z           | 0       | Table<br>21-7 |
| TMS             | Test mode select | Debug             | Carries commands to the TAP controller for boundary scan operations. Internally pulled up.                     |                | I       | Table<br>21-7 |
| TRST_B          | Test reset       | Debug             | Resets the TAP controller asynchronously.                                                                      | -              | I       | Table<br>21-7 |
| TEST_SEL_B      | Test select 1    | Test              | Factory test. Must be negated (pulled high) for normal operation.                                              | -              | I       | Table<br>21-7 |
|                 |                  |                   | <b>NOTE:</b> For P1012, TEST_SEL is an active high signal and needs to be pulled low to disable factory test.  |                |         |               |
| SCAN_MOD<br>E_B | Test             | Test              | Factory Test. Refer to the P1021 QorlQ Integrated Host Processor Hardware Specifications for proper treatment. | -              | I       | Table<br>21-7 |

<sup>1.</sup> While these signals are normally bidirectional, when sourcing debug information they are output only.

## 21.2.2 Detailed signal descriptions

This section describes the details of the debug, watchpoint monitor, and JTAG test signals.

## 21.2.2.1 Debug signals-details

The table below describes all signals associated with device debug modes.

Table 21-5. Debug signals-detailed signal descriptions

| Signal | l/<br>0 |                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|--------|---------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MDVAL  | 0       |                  | ata-valid. Indicates when valid data is available. May be used by a logic analyzer to e data on the data bus.                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|        |         | State<br>Meaning | Asserted-Indicates that data is valid on the data bus during the current clock cycle. When the DDR SDRAM interface is selected to source information on MDVAL, this signal is v alid for every cycle that data is driven or received on the DDR SDRAM interface. When the eLBC is selected, this signal is valid for every cycle that data is driven or received on the local bus interface. The assertion of this signal may be used by a logic analyzer to capture data. |  |  |  |
|        |         | Timing           | Asserted/Negated-Referenced to the selected interface, (DDR or local bus). Asserts when data is valid. Assertions are held for the duration of the transfer. Read data timing is similar to MA. Write data timing is similar to the output MDQ.                                                                                                                                                                                                                            |  |  |  |

Table 21-5. Debug signals-detailed signal descriptions (continued)

| Signal      | l/<br>0 |                  | Description                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|-------------|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| MECC[0:7]   | 0       | memory E         | emory ECC. DDR error checking and correcting. The normally bidirectional operation of the emory ECC (MECC) bus is described in Error checking and correcting (ECC). This bus is used r debug functions when MSRCID1 is sampled low during POR.                                                                      |  |  |  |  |  |
|             |         | _                | mode, the high-order 5 bits (MECC[0:4]) may be used to provide the transaction source ECC5 can be used as the data-valid indicator.                                                                                                                                                                                 |  |  |  |  |  |
|             |         |                  | node, MECC[0:5] is constantly driven with debug information and must be disconnected DDR memory's ECC pins.                                                                                                                                                                                                         |  |  |  |  |  |
|             |         | State<br>Meaning | Asserted/Negated-In debug mode, MECC[0:5] is always driven. The source ID values appear during RAS and CAS cycles. A value of 0x1F (all ones) is driven during cycles other than RAS and CAS. The data-valid indicator appears when data is being received or driven on the pins.                                   |  |  |  |  |  |
|             |         | Timing           | Driven every cycle in debug mode.                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| MSRCID[0:4] | 0       | ID for a tra     | ource ID. Attribute signals associated with the memory interface that indicate the source ansaction on an SDRAM interface. The SDRAM interface, DDR or local bus, to which the ormation applies is specified during POR with MSRCID0 as shown in Table 21-1. Two of als serve as reset configuration input signals. |  |  |  |  |  |
|             |         | State<br>Meaning | rissorios, regarda in assag mesas, amays amon mar are value or are source in                                                                                                                                                                                                                                        |  |  |  |  |  |
|             |         | Timing           | Driven every cycle in debug mode. Similar timing to MA.                                                                                                                                                                                                                                                             |  |  |  |  |  |

## 21.2.2.2 Watchpoint monitor trigger signals-details

The table below shows detailed descriptions of the watchpoint monitor and trace buffer signals.

Table 21-6. Watchpoint and trigger signals-detailed signal descriptions

| Signal  | I/<br>O                                                                                                                                                         |        | Description                                                                                                                                                                                           |  |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| TRIG_IN | I                                                                                                                                                               |        | Can be used to trigger the watchpoint and trace buffers. Note this is an active-high (rising-ered) signal.                                                                                            |  |  |  |
|         | State Asserted-Indicates that a programmed/armed external event has been detected. A may be used internally to trigger trace buffers and watchpoint mechanisms. |        |                                                                                                                                                                                                       |  |  |  |
|         |                                                                                                                                                                 | Timing | Assertion/Negation-The P1021 interprets TRIG_IN as asserted on detection of the rising edge. It may occur at any time. Must remain asserted for at least 3 system clocks to be recognized internally. |  |  |  |

Table 21-6. Watchpoint and trigger signals-detailed signal descriptions (continued)

| Signal   | 1/<br>O |                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|----------|---------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| TRIG_OUT | 0       | triggering<br>the perform<br>with REAL<br>modes). S                                   | t. Function determined by TOSR[SEL]. When TOSR[SEL] is non-zero, it can be used for external devices, like a logic analyzer, with either the watchpoint monitor, the trace buffer, or mance monitor as trigger sources. When TOSR[SEL] is cleared, TRIG_OUT is multiplexed DY, which indicates the operational readiness of the device (running or in low-power or debug ee Reset, Clocking, and Initialization and Global Utilities, for more details about reset, low-d debug states. |  |  |  |  |  |
|          |         | State<br>Meaning                                                                      | Asserted-When TOSR[SEL] is all zeros, serves as the READY signal, indicating that the device is not in a low-power or debug mode and that it has emerged from reset. SEL ≠ 0 indicates that a programmed trigger event has occurred.  Negation-No final watchpoint match condition                                                                                                                                                                                                      |  |  |  |  |  |
|          |         | Timing Assertion may occur at any time. Remains asserted for at least 3 system clocks |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |

## 21.2.2.3 JTAG test signals-details

The table below shows detailed descriptions of the JTAG test signals.

Table 21-7. JTAG test and other signals-detailed signal descriptions

| Signal | l/<br>0 |                  | Description                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|--------|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| TCK    | ı       | JTAG test        | clock.                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|        |         | State<br>Meaning | Asserted/Negated-Should be driven by a free-running clock signal with a 30-70% duty cycle. Input signals to the TAP are clocked in on the rising edge. Changes to the TAP output signals occur on the falling edge. The test logic allows TCK to be stopped. An unterminated input appears as a high signal level to the test logic due to an internal pull-up resistor. |  |  |  |  |
|        |         | Timing           | See IEEE 1149.1 standard for more details.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| TDI    | I       | JTAG test        | data input.                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|        |         | State<br>Meaning | Asserted/Negated-The value present on the rising edge of TCK is clocked into the selected JTAG test instruction or data register. An unterminated input appears as a high signal level to the test logic due to an internal pull-up resistor.                                                                                                                            |  |  |  |  |
|        |         | Timing           | See IEEE 1149.1 standard for more details.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| TDO    | 0       | JTAG test        | data output.                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|        |         | State<br>Meaning | Asserted/Negated-The contents of the selected internal instruction or data register are shifted out on this signal on the falling edge of TCK. Remains in a high-impedance state except when scanning data.                                                                                                                                                              |  |  |  |  |
|        |         | Timing           | See IEEE 1149.1 standard for more details.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| TMS    | I       | JTAG test        | mode select.                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|        |         | State<br>Meaning | Asserted/Negated-Decoded by the internal JTAG TAP controller to distinguish the primary operation of the test support circuitry. An unterminated input appears as a high signal level to the test logic due to an internal pull-up resistor.                                                                                                                             |  |  |  |  |
|        |         | Timing           | See IEEE 1149.1 standard for more details.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |

Table 21-7. JTAG test and other signals-detailed signal descriptions (continued)

| Signal          | l/<br>O |                           | Description                                                                                    |  |  |  |  |  |
|-----------------|---------|---------------------------|------------------------------------------------------------------------------------------------|--|--|--|--|--|
| TRST_B          | I       | JTAG test                 | reset.                                                                                         |  |  |  |  |  |
|                 |         | State<br>Meaning          | · · · · · · · · · · · · · · · · · · ·                                                          |  |  |  |  |  |
|                 |         | Timing                    | Timing See IEEE 1149.1 standard for more details.                                              |  |  |  |  |  |
| SCAN_MODE_<br>B | I       | Used for for proper treat | actory test. Refer to the P1021 QorIQ Integrated Processor Hardware Specifications for atment. |  |  |  |  |  |
| TEST_SEL_B      | I       | Used for f                | actory test. Should be negated (pulled high) for normal operation.                             |  |  |  |  |  |

## 21.3 Debug Memory Map/Register Definition

The table below shows the memory-mapped debug and watchpoint registers of the P1021. Any undefined 4-byte address spaces within offset 0x000-0xFFF are reserved.

#### debug memory map

| Offset address (hex) | Register name                                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_2000               | Watchpoint monitor control register 0 (debug_WMCR0)        | 32                 | R/W    | 0000_0000h  | 21.3.1/1595      |
| E_2004               | Watchpoint monitor control register 1 (debug_WMCR1)        | 32                 | R/W    | 0000_0000h  | 21.3.2/1597      |
| E_200C               | Watchpoint monitor address register (debug_WMAR)           | 32                 | R/W    | 0000_0000h  | 21.3.3/1598      |
| E_2014               | Watchpoint monitor address mask register (debug_WMAMR)     | 32                 | R/W    | 0000_0000h  | 21.3.4/1598      |
| E_2018               | Watchpoint monitor transaction mask register (debug_WMTMR) | 32                 | R/W    | 0000_0000h  | 21.3.5/1599      |
| E_201C               | Watchpoint monitor status register (debug_WMSR)            | 32                 | R/W    | 0000_0000h  | 21.3.6/1600      |
| E_2040               | Trace buffer control register 0 (debug_TBCR0)              | 32                 | R/W    | 0000_0000h  | 21.3.7/1601      |
| E_2044               | Trace buffer control register 1 (debug_TBCR1)              | 32                 | R/W    | 0000_0000h  | 21.3.8/1603      |
| E_204C               | Trace buffer address register (debug_TBAR)                 | 32                 | R/W    | 0000_0000h  | 21.3.9/1604      |
| E_2054               | Trace buffer address mask register (debug_TBAMR)           | 32                 | R/W    | 0000_0000h  | 21.3.10/<br>1604 |
| E_2058               | Trace buffer transaction mask register (debug_TBTMR)       | 32                 | R/W    | 0000_0000h  | 21.3.11/<br>1605 |
| E_205C               | Trace buffer status register (debug_TBSR)                  | 32                 | R/W    | 0000_0000h  | 21.3.12/<br>1606 |

#### debug memory map (continued)

| Offset address (hex) | Register name                                         | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------|
| E_2060               | Trace buffer access control register (debug_TBACR)    | 32                 | R/W    | 0000_0000h  | 21.3.13/<br>1607 |
| E_2064               | Trace buffer access data high register (debug_TBADHR) | 32                 | R/W    | 0000_0000h  | 21.3.14/<br>1607 |
| E_2068               | Trace buffer access data register (debug_TBADR)       | 32                 | R/W    | 0000_0000h  | 21.3.15/<br>1608 |
| E_20A0               | Programmed context ID register (debug_PCIDR)          | 32                 | R/W    | 0000_0000h  | 21.3.16/<br>1608 |
| E_20A4               | Current context ID register (debug_CCIDR)             | 32                 | R/W    | 0000_0000h  | 21.3.17/<br>1609 |
| E_20B0               | Trigger output source register (debug_TOSR)           | 32                 | R/W    | 0000_0000h  | 21.3.18/<br>1609 |

## 21.3.1 Watchpoint monitor control register 0 (debug\_WMCR0)

The watchpoint monitor control registers (WMCR0, WMCR1) control the specification of watchpoint monitor events.

Address: E\_2000h base + 0h offset = E\_2000h



#### debug\_WMCR0 field descriptions

| Field | Description                                  |
|-------|----------------------------------------------|
| 0     | Enable                                       |
| EN    |                                              |
|       | 0 Watchpoint monitor events are not flagged. |
|       | 1 Watchpoint monitor events are flagged.     |

#### **Debug Memory Map/Register Definition**

## debug\_WMCR0 field descriptions (continued)

| Field         | Description                                                                                                                                                                                                              |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1             | Address match disable. Qualifies address match as a watchpoint event criterion.                                                                                                                                          |  |
| AMD           | Address matching is used to recognize a watchpoint event.                                                                                                                                                                |  |
|               | 1 Address matching does not affect watchpoint event detection.                                                                                                                                                           |  |
| 2<br>TMD      | Transaction match disable. Qualifies transaction type match (as defined in WMCR1[IFSEL] and WMTMF as a watchpoint event criterion.                                                                                       |  |
|               | <ul> <li>A transaction type match is used to recognize watchpoint events.</li> <li>A transaction type match does not affect watchpoint event detection.</li> </ul>                                                       |  |
| 3<br>ECEN     | Equal context enable. Qualifies the matching of current context with programmed context as a watchpoint event criterion, as written in the context registers described in Programmed context ID register (debug_PCIDR).  |  |
|               | NOTE: ECEN and NECEN must not be enabled in the same run. If both are set, watchpoint events are inhibited (never occur).                                                                                                |  |
|               | Current context match does not affect watchpoint event detection.                                                                                                                                                        |  |
|               | 1 Watchpoint events are qualified by comparing current context with the programmed context event value.                                                                                                                  |  |
| 4<br>NECEN    | Not equal context enable. Qualifies the matching of current context with programmed context as a watchpoint event criterion, as written in the context registers described in Current context ID register (debug_CCIDR). |  |
|               | NOTE: ECEN and NECEN must not be enabled in the same run. If both are set, watchpoint events are inhibited (never occur).                                                                                                |  |
|               | 0 The failure of a current context match does not affect watchpoint event detection                                                                                                                                      |  |
|               | 1 Watchpoint events are qualified with NOT getting a current context compare with the programmed context event value.                                                                                                    |  |
| 5             | Source ID enable                                                                                                                                                                                                         |  |
| SIDEN         | Source ID does not affect watchpoint event detection.                                                                                                                                                                    |  |
|               | 1 Watchpoint events are qualified by comparison with the programmed WMCR1(SID) value.                                                                                                                                    |  |
| 6             | Target ID enable                                                                                                                                                                                                         |  |
| TIDEN         | 0 Target ID does not affect watchpoint event detection.                                                                                                                                                                  |  |
|               | 1 Watchpoint events are qualified by comparison with the programmed WMCR1(TID) value.                                                                                                                                    |  |
| 7–20<br>-     | This field is reserved. Reserved                                                                                                                                                                                         |  |
| 21–23<br>STRT | Start condition. Specifies the event that arms the watchpoint monitor to start looking for the programmed event.                                                                                                         |  |
|               | 000 No event. Armed immediately                                                                                                                                                                                          |  |
|               | 001 Trace buffer event is detected                                                                                                                                                                                       |  |
|               | 010 Performance monitor signals overflow                                                                                                                                                                                 |  |
|               | 011 TRIG_IN transitions from 0 to 1                                                                                                                                                                                      |  |
|               | 100 TRIG_IN transitions from 1 to 0                                                                                                                                                                                      |  |
|               | 101 Current context ID equals programmed context ID  110 Current context ID is not equal to programmed context ID                                                                                                        |  |
|               | 111 Reserved                                                                                                                                                                                                             |  |
|               |                                                                                                                                                                                                                          |  |

#### debug\_WMCR0 field descriptions (continued)

| Field      | Description                      |
|------------|----------------------------------|
| 24–31<br>- | This field is reserved. Reserved |

## 21.3.2 Watchpoint monitor control register 1 (debug\_WMCR1)

Address: E\_2000h base + 4h offset = E\_2004h



#### debug\_WMCR1 field descriptions

| Field        | Description                                                                                                                      |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0–4          | This field is reserved. Reserved                                                                                                 |  |  |
| 5–7<br>IFSEL | Interface selection. Selects the address, transaction type (as defined in WMTMR), and other attributes to be used for comparison |  |  |
|              | 000 Selects e500 coherency module (ECM) dispatch interface 001 Reserved                                                          |  |  |
|              | 010 Reserved                                                                                                                     |  |  |
|              | 011 Reserved                                                                                                                     |  |  |
|              | 100 Selects internal PCI Express 1 outbound interface                                                                            |  |  |
|              | 101 Selects internal PCI Express 2 outbound interface                                                                            |  |  |
|              | 110 Reserved                                                                                                                     |  |  |
|              | 111 Reserved                                                                                                                     |  |  |
| 8–10<br>-    | This field is reserved. Reserved                                                                                                 |  |  |
| 11–15<br>SID | Source ID. Specifies the source ID associated with WMCR0[SIDEN]. For a definition of the source ID, see Table 21-27.             |  |  |
| 16–26<br>-   | This field is reserved. Reserved                                                                                                 |  |  |
| 27–31<br>TID | Target ID. Specifies the target ID associated with WMCR0[TIDEN]. For a definition of the target ID see Table 21-27.              |  |  |

## 21.3.3 Watchpoint monitor address register (debug\_WMAR)

The watchpoint monitor address register (WMAR) contains the address to match against if WMCR[AMD] is clear. Note that this address may be further qualified with the bits described in Watchpoint monitor address mask register (debug\_WMAMR).





#### debug\_WMAR field descriptions

| Field       | Description                 |
|-------------|-----------------------------|
| 0–31<br>WMA | Watchpoint monitor address. |

## 21.3.4 Watchpoint monitor address mask register (debug\_WMAMR)

The watchpoint monitor address mask register (WMAMR) contains the mask for the address in the WMAR.

Address: E\_2000h base + 14h offset = E\_2014h



#### debug\_WMAMR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WMAM  | Watchpoint monitor address mask. A value of zero masks the address comparison for the corresponding address bit. These bits only mask the address bits generated by the hardware, but do not affect the bits specified in WMAR. A bit that is masked from the comparison should be set to 0 in WMAR. |

## 21.3.5 Watchpoint monitor transaction mask register (debug\_WMTMR)

The watchpoint monitor transaction mask register (WMTMR), specifies which transaction types to monitor. WMTMR allows users to qualify watchpoint events specifically with any combination of transaction types. As shown in the table below, each bit represents as many as four separate transaction types; one for each interface. Setting a bit enables watchpoint monitoring for the corresponding transaction types.

Because the supported transaction types vary by interface, the type designated by a WMTMR field also depends on the interface specified by WMCR1[IFSEL]. The table below lists transaction types associated with each WMTMR bit by interface.

The following table defines the transactions associated with each transaction mask bit for the different interfaces supported by the watchpoint monitor.

Bit Description e500 Coherency Module **DDR Controller PCI Express Outbound** Dispatch **Transaction** 0 Write with local processor Write Posted Write 1 Write with no local processor Non-posted Write snoop 2 Write with allocate(L2 Write with allocate stashing) 3 Write with allocate and lock Write with allocate and lock (L2 stashing with locking) 4 Reserved 5 Reserved 6 Reserved 7 Reserved 8 Read with local processor Read Read snoop 9 Read with no local processor snoop 10 Read with unlock Read with unlock 11 Reserved Read Response 12 Reserved 13-15 Reserved 16 ATOMIC clear ATOMIC clear 17 ATOMIC set ATOMIC set 18 ATOMIC decrement ATOMIC decrement

Table 21-13. Transaction Types by Interface

**Table 21-13. Transaction Types by Interface (continued)** 

| Bit   | Description                       |                  |                                     |
|-------|-----------------------------------|------------------|-------------------------------------|
|       | e500 Coherency Module<br>Dispatch | DDR Controller   | PCI Express Outbound<br>Transaction |
| 19    | ATOMIC increment                  | ATOMIC increment | -                                   |
| 20-24 | Reserved                          | -                | -                                   |
| 25    | Address only transaction          | -                | -                                   |
| 26-31 | Reserved                          | -                | -                                   |

Address: E\_2000h base + 18h offset = E\_2018h



#### debug\_WMTMR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WMTM  | Watchpoint monitor transaction mask. Each bit corresponds to a transaction type as defined in Table 21-13. The transaction associated with any particular bit may be different depending on the interface being monitored. A value of 1 for a given mask bit enables the matching of the transaction associated with that bit. These bits are meaningful only when WMCR0[TMD] = 0. |

## 21.3.6 Watchpoint monitor status register (debug\_WMSR)

The watchpoint monitor status register (WMSR) indicates the state of the watchpoint monitor.

Address: E\_2000h base + 1Ch offset = E\_201Ch



#### debug\_WMSR field descriptions

| Field    | Description |
|----------|-------------|
| 0<br>ACT | Active      |

## debug\_WMSR field descriptions (continued)

| Field | Description                                                                   |
|-------|-------------------------------------------------------------------------------|
|       | The start triggering event has not occurred; watchpoint monitor is not armed. |
|       | 1 The start triggering event has occurred; watchpoint monitor is armed.       |
| 1     | Triggered                                                                     |
| TRIG  |                                                                               |
|       | 0 The programmed event in WMCR0 has not yet been triggered.                   |
|       | 1 The programmed event in WMCR0 has been triggered at least once.             |
| 2–31  | This field is reserved.                                                       |
| -     | Reserved                                                                      |

## 21.3.7 Trace buffer control register 0 (debug\_TBCR0)

The trace buffer control register 0 (TBCR0) specifies trace buffer events.

Address: E\_2000h base + 40h offset = E\_2040h



#### debug\_TBCR0 field descriptions

| Field | Description                                                                  |  |
|-------|------------------------------------------------------------------------------|--|
| 0     | Enable                                                                       |  |
| EN    | O. The trace buffer facility is disabled                                     |  |
|       | O The trace buffer facility is disabled.                                     |  |
|       | 1 The trace buffer facility is enabled.                                      |  |
| 1     | Address match disable                                                        |  |
| AMD   |                                                                              |  |
|       | 0 The address match is used to qualify a trace buffer event.                 |  |
|       | 1 The address match is ignored when detecting a trace buffer event.          |  |
| 2     | Transaction match disable                                                    |  |
| TMD   |                                                                              |  |
|       | 0 The transaction type match is used to qualify a trace buffer event.        |  |
|       | 1 The transaction type match is ignored when detecting a trace buffer event. |  |

Table continues on the next page...

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

## debug\_TBCR0 field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>ECEN     | Equal context enable. Qualifies the matching of current context with programmed context as a trace buffer event criterion, as written in the context registers described in Programmed context ID register (debug_PCIDR).            |
|               | NOTE: ECEN and NECEN must not be enabled in the same run. If both are set, watchpoint events are inhibited (never occur).                                                                                                            |
|               | <ul> <li>Current context match does not affect trace buffer event detection</li> <li>Trace buffer events are qualified by comparing current context with the programmed context event value.</li> </ul>                              |
| 4<br>NECEN    | Not equal context enable. Qualifies the matching of current context with programmed context as a trace buffer event criterion, as written in the context registers described in Programmed context ID register (debug_PCIDR).        |
|               | NOTE: ECEN and NECEN must not be enabled in the same run. If both are set, watchpoint events are inhibited (never occur).                                                                                                            |
|               | 0 The failure of a current context match does not affect trace buffer event detection                                                                                                                                                |
|               | 1 trace buffer events are qualified with NOT getting a current context compare with the programmed context event value.                                                                                                              |
| 5<br>SIDEN    | Source ID enable                                                                                                                                                                                                                     |
| SIDEN         | 0 Trace buffer events ignore the programmed source ID value.                                                                                                                                                                         |
|               | 1 Trace buffer events are qualified by comparison with the programmed SID event value.                                                                                                                                               |
| 6<br>TIDEN    | Target ID enable                                                                                                                                                                                                                     |
|               | 0 Trace buffer events ignore the programmed TID event value.                                                                                                                                                                         |
|               | 1 Trace buffer events are qualified by comparison with the programmed TID event value. This comparison only applies when the ECM is selected for tracing (TBCR1[IFSEL] is all zeros).                                                |
| 7<br>HALT     | Halt causes the trace buffer to stop tracing immediately. TBSR[ACT] remains set when this bit is set.                                                                                                                                |
| 8–13<br>-     | This field is reserved. Reserved                                                                                                                                                                                                     |
| 14–15<br>MODE | Trace mode. Specifies one of two trace modes.                                                                                                                                                                                        |
| WODE          | 00 Trace every valid transaction                                                                                                                                                                                                     |
|               | 01 Reserved                                                                                                                                                                                                                          |
|               | <ul> <li>Trace only cycles in which a trace event is detected. Note that if EN and other TBCR0 fields are not properly programmed to specify a traceable event, tracing occurs for every valid address.</li> <li>Reserved</li> </ul> |
| 16–20         | This field is reserved.                                                                                                                                                                                                              |
| -             | Reserved                                                                                                                                                                                                                             |
| 21–23<br>STRT | Start condition. Specifies the event that arms the trace buffer to start looking for the programmed event                                                                                                                            |
|               | 000 No event. Armed immediately                                                                                                                                                                                                      |
|               | 001 Watchpoint monitor event is detected 010 Trace buffer event is detected                                                                                                                                                          |
|               | 011 Performance monitor signals overflow                                                                                                                                                                                             |
|               | 100 TRIG_IN transitions from 0 to 1                                                                                                                                                                                                  |
|               | 101 TRIG_IN transitions from 1 to 0                                                                                                                                                                                                  |

#### debug\_TBCR0 field descriptions (continued)

| Field | Description                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------|
|       | 110 Current context ID equals programmed context ID                                                         |
|       | 111 Current context ID does not equal programed context ID                                                  |
| 24–28 | This field is reserved.                                                                                     |
| -     | Reserved                                                                                                    |
| 29–31 | Trace stop mode. Specifies the event that stops the updating of the trace buffer after it has been started. |
| STOP  | Trace buffer only stops after it has been triggered at least once.                                          |
|       | 000 Buffer is full                                                                                          |
|       | 001 Watchpoint monitor event is detected                                                                    |
|       | 010 Trace buffer event is detected                                                                          |
|       | 011 Performance monitor signals overflow                                                                    |
|       | 100 TRIG_IN transitions from 0 to 1                                                                         |
|       | 101 TRIG_IN transitions from 1 to 0                                                                         |
|       | 110 Current context ID equals programmed context ID                                                         |
|       | 111 Current context ID does not equal programed context ID                                                  |

## 21.3.8 Trace buffer control register 1 (debug\_TBCR1)

The trace buffer control register 1 (TBCR1) specifies trace buffer events.

Address: E\_2000h base + 44h offset = E\_2044h



#### debug\_TBCR1 field descriptions

| Field        | Description                                                                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–4          | This field is reserved. Reserved                                                                                                                                                                                                        |
| 5–7<br>IFSEL | Interface selection. Specifies the interface that sources information for both comparison/buffer control and buffer data capture.                                                                                                       |
|              | 000 Selects e500 coherency module (ECM) dispatch interface 001 Reserved 010 Reserved 101 Reserved 100 Selects internal PCI Express 1 outbound interface 101 Selects internal PCI Express 2 outbound interface 110 Reserved 111 Reserved |

#### debug\_TBCR1 field descriptions (continued)

| Field        | Description                                                                                               |
|--------------|-----------------------------------------------------------------------------------------------------------|
| 8–10<br>-    | This field is reserved. Reserved                                                                          |
| 11–15<br>SID | Source ID. Specifies the source ID associated with TBCR0[SIDEN]. The source ID is defined in Table 21-27. |
| 16–26<br>-   | This field is reserved. Reserved                                                                          |
| 27–31<br>TID | Target ID. Specifies the target ID associated with TBCR0[TIDEN]. The target ID is defined in Table 21-27. |

## 21.3.9 Trace buffer address register (debug\_TBAR)

The trace buffer address register (TBAR) contains the address to match against (if TBCR0[AMD] is zero). This address may be further qualified by the mask bits defined in Trace buffer address mask register (debug\_TBAMR).

Address: E 2000h base + 4Ch offset = E 204Ch



#### debug\_TBAR field descriptions

| Field       | Description           |
|-------------|-----------------------|
| 0–31<br>TBA | Trace buffer address. |

## 21.3.10 Trace buffer address mask register (debug\_TBAMR)

The trace buffer address mask register (TBAMR) contains a mask for the TBAR, which allows excluding address bits from the comparison.

Address: E 2000h base + 54h offset = E 2054h



#### debug\_TBAMR field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>TBAM | Trace buffer address mask. A value of zero masks the address comparison for the corresponding address bit. These bits only mask the address bits generated by the hardware, but do not affect the bits specified in TBAR. A bit that is masked from the comparison should be set to 0 in TBAR. |

## 21.3.11 Trace buffer transaction mask register (debug\_TBTMR)

The trace buffer transaction mask register (TBTMR) specifies which transaction types to monitor. Each bit in the TBTMR represents a transaction type on the selected interface. The transaction associated with any particular bit depends on the interface being monitored as specified by TBCR1[IFSEL]. Note that the transactions used for defining trace buffer events are the same as those defined for watchpoint monitor events. Thus, Table 21-13 defines the transaction types associated with each interface. Setting a bit enables a hit when this transaction is matched (provided all other match criteria are met and TBCR0[TMD] is clear).

Different interfaces support different transaction types, and the same bit may represent different transaction types depending on the interface.

Address: E\_2000h base + 58h offset = E\_2058h



#### debug\_TBTMR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Trace buffer transaction mask. Each bit corresponds to a transaction type as defined in Table 21-13. The transaction associated with a bit depends on the interface being monitored. A value of 1 for a given mask bit enables the matching of the transaction associated with that bit. These bits are meaningful only when TBCR0[TMD] = 0. |

## 21.3.12 Trace buffer status register (debug\_TBSR)

The trace buffer status register (TBSR) indicates the operational state of the trace buffer.





#### debug\_TBSR field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>ACT        | Active. Indicates trace buffer activity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | 0 The start triggering event has not yet occurred. Trace buffer is not armed.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                 | 1 The start triggering event has occurred. Trace buffer is armed.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1<br>TRIG       | Triggered. Indicates whether or not a programmed event has been triggered.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 0 The programmed event in TBCR0 has not yet been triggered.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 1 The programmed event in TBCR0 has been triggered at least once.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2<br>STP        | Stopped. Indicates whether or not a trace buffer stop condition has been detected.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                 | 0 No stop condition yet detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 | 1 The trace buffer has detected a stop condition and is no longer capturing events.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3<br>WRAP       | Wrapped. Indicates that the trace buffer write pointer has wrapped to the beginning of the buffer at least once. Set when the last entry of the trace buffer is written.                                                                                                                                                                                                                                                                                                                                                        |
|                 | 0 Pointer has not yet wrapped.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 | 1 Pointer has wrapped to the beginning at least once.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4–23<br>-       | This field is reserved. Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24–31<br>C_INDX | Current index. Represents the current value of the write pointer at the time TBSR was read. This value may be written by software to initialize the write pointer; however, software is not allowed to write to the write pointer while the trace buffer is active. Writes are ignored while the trace buffer is active. It is recommended to write the status register before enabling the trace buffer in order to zero out any bits that might have been set during a prior run and to initialize the write pointer to zero. |

## 21.3.13 Trace buffer access control register (debug\_TBACR)

The trace buffer access control register (TBACR) enables software to read or write the trace buffer. Each entry is 64 bits; therefore, it takes one write of TBACR and two reads of the access data register (TBADR and TBADHR) to read one 256-entry array entry. Similarly, it takes one write of TBACR and two writes of TBADR and TBADHR to write one array entry. Software can access any entry by writing the appropriate index into TBACR[INDX]. To read or write the buffer sequentially, starting with entry 0, the index must start with a value of 0 and increment every time a new entry is accessed.





#### debug\_TBACR field descriptions

| Field         | Description                                                                                                                                                                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RD       | Read command. When set, a trace buffer read is performed using the value of TBACR[INDX]. This bit is automatically cleared when the read is performed.                                                                                                                  |
| 1<br>WR       | Write command. When set, a trace buffer write is performed using the value of TBACR[INDX]. This bit is automatically cleared when the write is performed. A write occurs only if the trace buffer is not active: write requests are ignored while the buffer is active. |
| 2–23<br>-     | This field is reserved. Reserved                                                                                                                                                                                                                                        |
| 24–31<br>INDX | Buffer index to read from or write into (0-255). Used in conjunction with TBACR[RD] and TBACR[WR].                                                                                                                                                                      |

## 21.3.14 Trace buffer access data high register (debug\_TBADHR)

The trace buffer access data high register (TBADHR), contains one of the following:

- High-order 32 bits of the data read from the trace buffer during a software-initiated read command (TBACR[RD])
- Or, data to be written into the trace buffer during a software-initiated write command (TBACR[WR]).

#### **Debug Memory Map/Register Definition**

TBACR must be configured to perform a read before TBADHR contains valid data. This register must be initialized by software before configuring the TBACR to perform a write command.

Address: E\_2000h base + 64h offset = E\_2064h



#### debug\_TBADHR field descriptions

| Field         | Description                                                                                                                                                                        |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>TBADH | Trace buffer access data high. The higher 32 bits of the data read from or to be written into the trace buffer, depending on whether the array is accessed with a read or a write. |

## 21.3.15 Trace buffer access data register (debug\_TBADR)

The trace buffer access data register (TBADR), contains the low-order 32 bits of the data read from the trace buffer during a software-initiated read command (TBACR[RD]) or the write data to be written into the trace buffer during a software-initiated write command (TBACR[WR]). TBACR must be configured to perform a read before this register contains valid data. This register must be initialized by software before configuring the TBACR to perform a write command.

Address: E\_2000h base + 68h offset = E\_2068h



#### debug\_TBADR field descriptions

| Field        | Description                                                                                                                                                                                                            |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–31<br>TBAD | Trace buffer access data. Corresponds to the lower 32 bits of the data read from the trace buffer or to be written into the trace buffer, depending on whether software is accessing the array with a read or a write. |

## 21.3.16 Programmed context ID register (debug\_PCIDR)

The programmed context ID registers (PCIDR) is set by software and facilitate debugging complex software.

The programmed context ID register (PCIDR), contains the user-programmed context ID. This register can be configured to trigger watchpoint events when its value matches the current context ID register (CCIDR), as controlled by WMCR0[ECEN] and WMCR0[NECEN]. See Watchpoint monitor control register 0 (debug\_WMCR0), for more information.





#### debug\_PCIDR field descriptions

|   | Field | Description                                                                                                                             |
|---|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Ī |       | Programmed context ID. Contains the user-programmed context ID. Compared with current context ID for context-sensitive event triggering |

## 21.3.17 Current context ID register (debug\_CCIDR)

The current context ID register (CCIDR) is set by software and facilitate debugging complex software.

The current context ID register (CCIDR) contains the current context ID. This register is written by software after a context switch and can be used to trigger events when compared with the programmed context ID register (PCIDR).

#### Address: E\_2000h base + A4h offset = E\_20A4h



#### debug\_CCIDR field descriptions

| Field | Description                                                                                                                                                                        |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Current context ID. Set by user software. Typically loaded immediately following a context switch. Compared with user-programmed context ID for context-sensitive event triggering |

## 21.3.18 Trigger output source register (debug\_TOSR)

TRIG\_OUT provides a convenient mechanism for triggering external system monitors and diagnostic equipment such as logic analyzers. Note that READY is multiplexed with TRIG\_OUT. See the last paragraph of Power-on reset sequence, for more information about READY functionality.

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### **Functional description**

When the trace buffer hit is selected by TOSR[SEL], TRIG\_OUT is only meaningful if the trace buffer control register 0 (TBCR0) is properly configured to hit on a traceable event. The same holds true for the watchpoint monitor when the watchpoint monitor is selected by TOSR[SEL].

The trigger out source register (TOSR) specifies the source for TRIG\_OUT. The three event-trigger sources are the following:

- The watchpoint monitor
- The trace buffer
- The performance monitor

Address: E\_2000h base + B0h offset = E\_20B0h



#### debug\_TOSR field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                 |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0–4        | This field is reserved. Reserved                                                                                                                                                                                                                                                                            |  |
| 5–7<br>SEL | Select. Selects the source for TRIG_OUT                                                                                                                                                                                                                                                                     |  |
|            | 000 READY signal. Multiplexed with TRIG_OUT. Basic device state indicator. READY asserts whenever the device is not in reset or not asleep. See the Reset, Clocking, and Initialization for more details about the reset sequence, and Global Utilities for more information about power management states. |  |
|            | 001 Selects the watchpoint monitor hit indication                                                                                                                                                                                                                                                           |  |
|            | 010 Selects the trace buffer hit indication                                                                                                                                                                                                                                                                 |  |
|            | 011 Selects the performance monitor overflow indication                                                                                                                                                                                                                                                     |  |
| 8–31<br>-  | This field is reserved. Reserved                                                                                                                                                                                                                                                                            |  |

## 21.4 Functional description

The debug features on the P1021 use the eLBC interfaces and the DDR SDRAM interfaces.

## 21.4.1 Source and target ID

Debug information that is common to all the interfaces is the source ID (SID).

The transaction source ID provides enough information to determine which block or port originated a transaction including the distinction between instruction and data fetches from the processor core. The table below shows the values and interpretation for the 5-bit SID field. Note that the table also includes ports that are only slaves, such as local memory. These ports are always targets. As such, the value shown represents a target ID (TID) and not a source ID. For ports that can function in both capacities, the value indicates source ID when mastering transactions, and target ID when responding as slave. The TID field is only meaningful when one of the following participates in the transaction:

- The e500 coherency module (ECM) dispatch bus
- The watchpoint monitor (WMCR1[IFSEL] = 000)
- The trace buffer (TBCR1[IFSEL] = 000)

Table 21-27. Source and target ID values

| ID Value<br>(Hex) | Transaction Source                    | Transaction Target   |
|-------------------|---------------------------------------|----------------------|
| 00                | Reserved                              | Reserved             |
| 01                | PCI Express 2                         | PCI Express 2        |
| 02                | PCI Express 1                         | PCI Express 1        |
| 03                | Reserved                              | Reserved             |
| 04                | Reserved                              | Local Bus Controller |
| 05                | USB                                   | Reserved             |
| 06                | Reserved                              | Reserved             |
| 07                | Security                              | Reserved             |
| 08                | Reserved                              | Reserved             |
| 09                | Reserved                              | Reserved             |
| 0A                | Boot sequencer                        | Reserved             |
| 0B                | eSDHC                                 | Reserved             |
| 0C                | Reserved                              | Reserved             |
| 0D                | Reserved                              | Reserved             |
| 0E                | Reserved                              | Reserved             |
| 0F                | DMA controller (DMAC)                 | DDR                  |
| 10                | Local Processor 0 (instruction fetch) | Reserved             |
| 11                | Local Processor 0 (data fetch)        | Reserved             |
| 12                | Local Processor 1 (instruction fetch) | Reserved             |
| 13                | Local Processor 1 (data fetch)        | Reserved             |
| 14                | QUICC Engine block                    | Reserved             |
| 15                | Direct memory access controller (DMA) | Reserved             |
| 16                | Reserved                              | Reserved             |
| 17                | System access port (SAP)              | Reserved             |
| 18                | eTSEC 1                               | Reserved             |

Table 21-27. Source and target ID values (continued)

| ID Value<br>(Hex) | Transaction Source | Transaction Target |
|-------------------|--------------------|--------------------|
| 19                | eTSEC 2            | Reserved           |
| 1A                | eTSEC 3            | Reserved           |
| 1B                | Reserved           | Reserved           |
| 1C                | Reserved           | Reserved           |
| 1D                | Reserved           | Reserved           |
| 1E                | Reserved           | Reserved           |
| 1F                | Reserved           | Reserved           |

## 21.4.2 DDR SDRAM interface debug

The DDR interface has two debug modes distinguished by which pins drive the debug information.

In one mode, debug information (source ID, data valid) is multiplexed onto the ECC pins; the other mode uses the debug pins.

## 21.4.2.1 Debug information on debug pins

If cfg\_mem\_debug is high when sampled during POR, the debug information from the DDR SDRAM controller is driven on MSRCID[0:4] and MDVAL.

This POR value is captured in PORDBGMSR[MEM\_SEL] as described in POR debug mode status register (GUTS\_PORDBGMSR). In this mode, the source ID appears on MSRCID[0:4] during a RAS or CAS cycle. During any other cycle, the value of MSRCID[0:4] is all ones, which indicates idle cycles on the address/command interface. Similarly, MDVAL is asserted during valid data cycles on the DDR interface.

## 21.4.2.2 Debug information on ECC pins

If MSRCID0 is low when sampled during POR, debug information from the DDR SDRAM interface is selected to appear on MECC[0:5] as shown in Figure 21-1. In this mode, the ID value of the source port (the source ID) appears on MECC[0:4] during a RAS or CAS cycle. During any other cycle, the value of MECC[0:4] is all ones. A data-valid signal (DVAL) is driven on MECC5 during valid DDR SDRAM data cycles.

#### NOTE

In this mode, MECC[0:5] must be disconnected from all SDRAM devices to prevent contention on those lines.

## 21.4.3 Local bus interface debug

If cfg\_mem\_debug is low when sampled during POR, the eLBC is selected as the source for the debug information appearing on MSRCID[0:4] and MDVAL.

For more information on this mode, see Source ID debug mode.

## 21.4.4 Watchpoint monitor

The watchpoint monitor (WM) can be programmed to arm and trigger on many different events including any of the following:

- External event (through TRIG\_IN)
- A trace buffer event
- A performance monitor overflow event
- A comparison of the current and programmed context ID registers

A watchpoint event can be used in the following ways:

- Trigger a logic analyzer (using TRIG\_OUT)
- Arm or trigger the trace buffer
- Trigger a performance monitor event

The large counters available in the performance monitor block and the interlock between it and the watchpoint monitor support sophisticated debug scenarios.

A WM trigger event may be composed of several events programmed in the watchpoint monitor control registers (WMCR0-WMCR1). Because the watchpoint monitor is disabled by default during POR, these registers must be initialized to make use of this debug feature. Note that the WM address mask register (WMAMR) and the type mask register (WMTMR) are cleared during POR. This means that the watchpoint monitor's default behavior following a power-on reset is to trigger on any address and no transaction type. The reset value of WMCR0[TMD] is 0 which means transaction matching is enabled but since no transaction is selected (WMTMR = 0), a match will never occur. Either the transaction matching must be disabled by setting WMCR0[TMD] to a value of 1, or valid transactions must be selected by setting one or more of the WMTMR bits to a value of 1.

#### 21.4.4.1 Watchpoint monitor performance monitor events

The WM can produce a performance monitor (PM) event with every trigger.

This is accomplished by configuring the performance monitor to count WM events. For more information on this configuration, see the events named "Number of watchpoint monitor hits" and "Number of trace buffer hits" in Performance monitor events.

Multilevel triggers can be created using the watchpoint monitor, the performance monitor, and the trace buffer combined. For example, the WM can be programmed to trigger on events that also increment a PM counter (the performance monitor must also be programmed to respond to this event), the output of which (perfmon\_overflow) could trigger the start of tracing in the trace buffer.

#### 21.4.5 Trace buffer

The trace buffer is a 256 entry x 64-bit array that can capture information about the internal processing of transactions to selected interfaces.

The trace buffer controls are a superset of those for the watchpoint monitor. Close inspection of the trace buffer control registers (TBCR*n*) and the watcpoint monitor control registers (WMCR*n*) shows that trace buffer controls not needed for the watcpoint monitor are marked reserved in WMCRn. This permits using the trace buffer as a second watchpoint monitor by simply ignoring the trace options.

The trace buffer provides great flexibility about when to start tracing, when to stop tracing, and what to trace. The trace mode field, TBCR0[MODE], indicates when to trace: on every valid cycle, on a watchpoint monitor event, or when all the programmed events in the TBCR are met. This permits a user to program the trace condition in the watchpoint monitor and to program a start or stop condition in the trace buffer control register. The user can also program the TBCR with the conditions in which to stop tracing: on an event, or when the buffer is full. TBCR0[IFSEL] specifies which interface transactions are being captured.

The trace buffer can be programmed to trace the dispatch bus from the e500 coherency module (ECM)

Transactions come into the ECM, arbitrate for common resources, and get dispatched to the target port. Information such as transaction types, source ID, and other attributes can be captured in any of the selected interfaces.

## 21.4.5.1 Traced data formats (as a function of TBCR1[IFSEL])

The figure below shows the trace buffer entry format for an ECM dispatch (CMD) transaction that is specified when TBCR1[IFSEL] = 000.



Table 21-29. CMD trace buffer entry field descriptions (TBCR1[IFSEL] = 000)

| Bits  | Name    | Function                                                                                                                                                       |
|-------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-4   | CMDTT   | Transaction type. Specifies the transaction type as shown in Table 21-13. For example, a value of zero indicates a write with local processor snoop condition. |
| 5-9   | CMDSID  | Source ID. Identifies the source of the transaction as shown in Table 21-27. For example, a value of 010101 indicates that DMA is the transaction source.      |
| 10-13 | CMDTID  | Target ID. Identifies the target of the transaction as shown in Table 21-27. For example, a value of 010101 indicates that DMA is the transaction target.      |
| 14-18 | CMDBC   | Byte count. Range: 32 to 1 where a value of 0 indicates 32 bytes.                                                                                              |
|       |         | 00000 = 32 bytes                                                                                                                                               |
|       |         | 00001 = 1 byte                                                                                                                                                 |
|       |         | 00010 = 2 bytes                                                                                                                                                |
|       |         |                                                                                                                                                                |
|       |         | 11110 = 30 bytes                                                                                                                                               |
|       |         | 11111 = 31 bytes                                                                                                                                               |
| 19-31 | -       | Reserved                                                                                                                                                       |
| 32-63 | CMDADDR | Address bits 0-31                                                                                                                                              |

Table 21-30 shows the PCI Express trace buffer entry format when TBCR1[IFSEL] = 100 or 101 or 110.



The table below describes the fields of PCI Express trace buffer entries when TBCR1[IFSEL] = 100 or 101 or 110.

#### Initialization

Table 21-31. PCI Express trace buffer entry field descriptions

| Bits  | Name    | Function                                                                                                                                                                                                                       |
|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-4   | PEXTT   | Transaction type. Specifies the transaction type as shown in Table 21-13. For example, a value of all zeros maps to write.                                                                                                     |
| 5-9   | PEXSID  | Source ID. Identifies the source of the transaction as shown in Table 21-27. For example, a value of 010101 identifies DMA as the transaction source. For responses, this corresponds to Requestor's ID's bus number bits 3-7. |
| 10-14 | PEXBC   | Byte count. The size of the transaction.                                                                                                                                                                                       |
|       |         | 00000 4 bytes                                                                                                                                                                                                                  |
|       |         | 00001 8 bytes                                                                                                                                                                                                                  |
|       |         | 00010 12 bytes                                                                                                                                                                                                                 |
|       |         |                                                                                                                                                                                                                                |
|       |         | 11111 256 bytes                                                                                                                                                                                                                |
| 15-33 | -       | Reserved                                                                                                                                                                                                                       |
| 34-63 | PEXADDR | Address bits 31-2                                                                                                                                                                                                              |

#### 21.5 Initialization

Configuring the appropriate control register must be the last step in the initialization sequence for either the watchpoint or trace buffer.

That is, all required registers except the corresponding control register must be configured before any control register bits that enable watchpoint or trace events are set.

# **Chapter 22 QUICC Engine Block**

QUICC Engine ™Block Reference Manual with Protocol Interworking (QEIWRM) describes all the functional units of the QUICC Engine block and must be used in conjunction with this device manual and this chapter. The QEIWRM is a superset manual which includes some information not relevant to the device. This chapter serves as both a general overview of the QUICC Engine block and a guide to the specific implementation of the QUICC Engine block on the device.

#### 22.1 Introduction

The *QUICC Engine*<sup>™</sup> *Block Reference Manual with Protocol Interworking* (QEIWRM) describes all the functional units of the QUICC Engine block and must be used in conjunction with this device manual and this chapter.

The QEIWRM is a superset manual which includes some information not relevant to the device. This chapter serves as both a general overview of the QUICC Engine block and a guide to the specific implementation of the QUICC Engine block on the device.

- QUICC engine block, gives a general overview of the QUICC Engine architecture and communication peripherals.
- QUICC engine implementation details, lists the chapters that do apply. Implementation-specific details for some chapters follow.

## 22.2 QUICC engine block

#### NOTE

Based on the microcode RAM package that is used, some of the features listed below may not be applicable. See the table below for the different features offered in each microcode configuration.

#### **QUICC** engine block

The QUICC Engine technology is a versatile communications complex that integrates several communications peripheral controllers. It provides on-chip system design for a variety of applications, particularly in communications and networking systems. The QUICC Engine technology has the following features:

- 32-bit RISC controller for flexible support of the communications peripherals
- Serial DMA channel for receive and transmit on all serial channels
- Universal communication controllers (UCCs) supporting the following protocols and interfaces (not all of them simultaneously):
  - 10/100 Mbps Ethernet/IEEE Std. 802.3 interfaces, using two RMII amd an MII
  - ATM protocol through UTOPIA
  - HDLC and Transparent controllers up to 50 Mbps full-duplex; HDLC bus up to 10 Mbps
  - UART and asynchronous HDLC
  - BISYNC up to 2 Mbps
  - UMCC
- UTOPIA L2 interface supporting 31 multi-PHY addresses
- Serial peripheral interface (SPI)
- TDM interfaces, with T1/E1/J1 serial interfaces
- ATM SAR up to 155 Mbps (OC-3) full duplex, with ATM traffic shaping (ATF TM4.1) for up to 64K ATM connections
- IMA and ATM transmission convergence sublayer, depending on microcode configuration
- ATM OAM handling features compatible with ITU-TI.610
- IP termination support for IPv4 and IPv6 packets including TOS, TTL, and header checksum processing
- Support for ATM statistics and Ethernet RMON/MIB statistics
- 256 channels of HDLC/Transparent per UCC
- IEEE 1588 V2 support
- RAM-based microcode

The table below provides the RAM-based microcode configurations offered for the device.

| Table 22-1. | RAM microcode conf | igurations offered | for the device |
|-------------|--------------------|--------------------|----------------|
|-------------|--------------------|--------------------|----------------|

| Feature               | Configuration 1 | Configuration 2 |
|-----------------------|-----------------|-----------------|
| QUICC Engine Ethernet | Yes             | -               |
| ATM                   | Yes             | Yes             |
| SAM                   | -               | Yes             |
| IMA                   | -               | Yes             |
| All other protocols   | Yes             | Yes             |

The figure below shows the internal architecture and the interfaces provided by the QUICC Engine block on the device. A RAM is used to store parameters for the RISC engine. The RISC has a ROM associated with it, which contains the code image. The instruction RAM is used to optionally run additional code.



Figure 22-1. QUICC engine block architectural block diagram

## 22.3 QUICC engine implementation details

The table below lists the chapters from the  $QUICC\ Engine^{TM}\ Block\ Reference\ Manual\ with\ Protocol\ Interworking\ (QEIWRM).$ 

Not all chapters of the QEIWRM apply to this device and those that do apply may have application differences. Use this overview section as a guide for these application differences.

While using the QEIWRM, note this implementation-specific information in general:

- Dual e500v2 cores
- One 32-bit RISC
- Four UCCs available-UCC1, UCC3, UCC5, UCC7
  - UCC1 supports RMII, MII
  - UCC5 supports RMII
- Up to four TDM ports
- One SPI
- One UPC

#### **QUICC** engine implementation details

- IEEE 1588v2 standard hardware support applies
- UMCC

The table below lists the chapters from the *QUICC Engine Block Reference Manual with Protocol Interworking* (QEIWRM) and the chapters with implementation differences.

Table 22-2. QEIWRM chapters and implementation

| Chapter Name                                   | Implementation                                                    |  |  |
|------------------------------------------------|-------------------------------------------------------------------|--|--|
| Part I, "Introduction"                         |                                                                   |  |  |
| System Interface                               | Applies to this device                                            |  |  |
|                                                | -see System interface for implementation                          |  |  |
| Configuration                                  | Applies to this device                                            |  |  |
|                                                | -see Configuration for implementation                             |  |  |
| Multiplexing and Timers                        | Applies to this device                                            |  |  |
|                                                | -see Multiplexing and timers for implementation                   |  |  |
| Part II, "Unified Communication Controllers (U | JCCs)"                                                            |  |  |
| Unified Communications Controllers (UCCs)      | Applies to this device                                            |  |  |
|                                                | -see Unified communications controllers (UCCs) for implementation |  |  |
| UCC for Fast Protocols                         | Applies to this device                                            |  |  |
|                                                | -see UCC for fast protocols for implementation                    |  |  |
| UCC Ethernet Controller (UEC)                  | Applies to this device                                            |  |  |
|                                                | -see UCC Ethernet controller (UEC) for implementation             |  |  |
| IEEE Standard 1588 Assist                      | Applies to this device                                            |  |  |
|                                                | -see IEEE standard 1588 assist for implementation                 |  |  |
| UTOPIA POS Bus Controller (UPC)                | Applies to this device                                            |  |  |
|                                                | -see UTOPIA POS bus controller (UPC) for implementation           |  |  |
| ATM Controller AAL0, AAL1, and AAL5            | Applies to this device                                            |  |  |
|                                                | -see ATM controller AAL0, AAL1, and AAL5 for implementation       |  |  |
| ATM Adaptation Layer 2                         | Does not apply to this device                                     |  |  |
| UCC POS Controller (UPOS)                      | Does not apply to this device                                     |  |  |
| HDLC Controller                                | Applies to this device                                            |  |  |
|                                                | -see HDLC controller for implementation                           |  |  |
| Transparent Controller                         | Applies to this device                                            |  |  |
|                                                | -see Transparent controller for implementation                    |  |  |
| UCC for Slow Protocols                         | Applies to this device                                            |  |  |
|                                                | -see UCC for slow protocols for implementation                    |  |  |
| UART Mode and Asynchronous HDLC                | Applies to this device                                            |  |  |
| Serial Peripheral Interface (SPI)              | Applies to this device                                            |  |  |
|                                                | -see Serial peripheral interface (SPI) for implementation         |  |  |
| Universal Serial Bus Controller                | Does not apply to this device                                     |  |  |

Table 22-2. QEIWRM chapters and implementation (continued)

| Chapter Name                                   | Implementation                                                   |
|------------------------------------------------|------------------------------------------------------------------|
| BISYNC Mode                                    | Applies to this device                                           |
|                                                | -see BISYNC mode for implementation                              |
| Part III, "Time Division Multiplex Support (TD | M)" <sup>1</sup>                                                 |
| Serial Interface with Time-Slot Assigner       | Applies to this device                                           |
|                                                | -see Serial interface with time-slot assigner for implementation |
| Multi-Channel Controller (MCC)                 | Does not apply to this device                                    |
| Multi-Channel Controller on UCC (UMCC)         | Applies to this device                                           |
| QUICC Multi-Channel Controller (QMC)           | Does not apply to this device                                    |
| Point-to-Point Protocol (PPP)                  | Does not apply to this device                                    |
| Serial ATM Microcode                           | Applies to this device                                           |
|                                                | -see Serial ATM microcode for implementation                     |
| Inverse Multiplexing for ATM (IMA)             | Applies to this device                                           |
|                                                | -see Inverse multiplexing for ATM (IMA) for implementation       |
| ATM AAL1 Circuit Emulation Service             | Does not apply to this device                                    |
| Part IV, "Multiprotocol Interworking"          |                                                                  |
| Interworking Introduction                      | Does not apply to this device                                    |
| Frame Parse and Lookup                         | Does not apply to this device                                    |
| Protocol Interworking Programming Model        | Does not apply to this device                                    |
| Virtual Port                                   | Does not apply to this device                                    |
| IP Reassembly                                  | Does not apply to this device                                    |
| IPv4/UDP Header Compression                    | Does not apply to this device                                    |
| IPsec Microcode Package                        | Does not apply to this device                                    |
| Part V, "Switching Functionality"              |                                                                  |
| Enhanced MSP Microcode                         | Does not apply to this device                                    |
| L2 Ethernet Switch                             | Does not apply to this device                                    |

<sup>1.</sup> The TDM can only work with an external sync and external clock; other options are not supported.

The following subsections include device-specific details for the given chapters of the QEIWRM.

#### 22.3.1 System interface

Of the UCCs, only UCC1, UCC3, UCC5, and UCC7 are supported on the device.

The following features are not supported: USB, MCC, SPI2, Ethernet TBI mode.

On this device, only a system bus is supported; references to a secondary bus should be disregarded. As such,

#### **QUICC** engine implementation details

- In the "Bus Selection Mechanisms" subsection, references to the secondary bus should be disregarded.
- In the "Serial DMA Status Register (SDSR)" subsection, the BER\_2 bit is not available and should be reserved.
- In the "Serial DMA Mode Register (SDMR)" subsection, BER\_2\_MSK and SBER\_2\_MSK bits are not available and should be reserved.
- In the "Serial DMA Transfer Address Registers (SDTA1 and SDTA2)" and "Serial DMA Transfer Communication Channel Number Registers (SDTM1 and SDTM2)" subsections, references to the secondary bus should be disregarded.

#### 22.3.1.1 System interface-data paths

In the "Data paths" subsection of the QEIWRM, use this e500 core information:

The figure below is a simplified block diagram that shows the data paths. The data paths include a path from the SDMA system bus interface to targets connected to the ECM. The e500 coherency module (ECM) block shown in the figure, is responsible for distribution of I/O masters transactions to the various possible targets (such as the PCI Express or DDR memory controller) based on the transaction's address. See Address translation and mapping units for further details. The SDMA channel must be configured for big-endian byte ordering for accessing buffer data. The big-endian byte ordering format is programmed in the receive and transmit bus mode registers associated with the peripherals (UMCC, SPI). Refer to each protocol of these peripherals for programming of this feature.



Figure 22-2. Data paths

#### 22.3.1.2 System interface-interrupt configuration

In the "Interrupt Configuration" subsection, use the figure below to show the QUICC Engine interrupt structure.



Figure 22-3. QUICC engine module interrupt structure

#### 22.3.1.3 System interface-bus arbitration

The "Bus Arbitration" subsection should be disregarded.

#### 22.3.2 Configuration

Of the UCCs, this device only supports UCC1, UCC3, UCC5, and UCC7.

The following features are not supported: USB, MCC, SPI2.

#### 22.3.2.1 Configuration-parameter RAM

For the device, replace the "Default Parameter RAM Base Addresses" table with the table below.

Table 22-3. Default parameter RAM base addresses

| Address | Peripheral       | Size (Bytes) |
|---------|------------------|--------------|
| 0x3400  | UCC1 (Rx and Tx) | 256          |

Table 22-3. Default parameter RAM base addresses (continued)

| Address | Peripheral       | Size (Bytes) |  |  |
|---------|------------------|--------------|--|--|
| 0x3600  | UCC3 (Rx and Tx) | 256          |  |  |
| 0x3000  | UCC5 (Rx and Tx) | 256          |  |  |
| 0x3200  | UCC7 (Rx and Tx) | 256          |  |  |
| 0x3900  | SPI (Rx and Tx)  | 128          |  |  |
| 0x3A00  | TIMER            | 64           |  |  |

#### 22.3.3 Multiplexing and timers

Of the UCCs, only UCC1, UCC3, UCC5, and UCC7 are supported; of the TDMs, only TDMA, TDMB, TDMC, and TDMD are supported.

USB and Ethernet TBI mode are not supported.

The following information applies:

- A bank of 18 external clocks: CLK1, CLK[3-16], CLK[19-21]
- Nine supported BRGs: BRG[1-2] and BRG[5-11].
- Four UCCs-UCC1, UCC3, UCC5, UCC7
- Four TDMs-TDMA, TDMB, TDMC, TDMD
- RTC CLK

#### 22.3.3.1 Multiplexing and timers-NMSI configuration

For the device, replace the "Bank of Clocks" figure with the figure below.



Figure 22-4. Bank of clocks

In the "NMSI Configuration" subsection, refer to the tables below.

The table below shows the clock source options for the serial controllers and TDM channels.

Table 22-4. Clock source options-external clock signals

| Clock                 | External CLK Number |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |         |
|-----------------------|---------------------|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|---------|
|                       | 1                   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 19 | 20 | 21 | RT<br>C |
| UCC1 Rx               |                     |   |   |   |   |   |   | ٧ | ٧  | ٧  | ٧  |    |    | ٧  | ٧  |    |    |    |         |
| UCC1 Tx               |                     |   |   |   |   |   |   | ٧ | V  | ٧  | ٧  |    |    | ٧  | ٧  |    |    |    |         |
| UCC3 Rx               |                     |   |   |   |   |   |   | ٧ | V  | ٧  | ٧  |    |    | ٧  | ٧  |    |    |    |         |
| UCC3 Tx               |                     |   |   |   |   |   |   | ٧ | V  | ٧  | ٧  |    |    | ٧  | ٧  |    |    |    |         |
| UCC5 Rx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UCC5 Tx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UCC7 Rx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UCC7 Tx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UPC1 Rx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UPC1 Tx               |                     |   |   |   |   |   |   |   |    |    |    | ٧  | ٧  | ٧  | ٧  | ٧  | ٧  |    |         |
| UPC1 IR               |                     |   |   |   |   |   |   |   |    |    |    |    |    |    |    | ٧  |    |    |         |
| TDMA1 Rx              | ٧                   | V |   |   |   |   | ٧ |   |    |    |    |    |    |    |    |    |    |    |         |
| TDMA1 Tx              | ٧                   |   | ٧ |   |   |   |   | ٧ |    |    |    |    |    |    |    |    |    |    |         |
| TDMB1 Rx              | ٧                   |   |   | ٧ |   |   |   |   | V  |    |    |    |    |    |    |    |    |    |         |
| TDMB1 Tx              | ٧                   |   |   |   | ٧ |   |   |   |    | ٧  |    |    |    |    |    |    |    |    |         |
| TDMC1 Rx              | ٧                   |   |   |   |   | ٧ |   |   |    |    | ٧  |    |    |    |    |    |    |    |         |
| TDMC1 Tx              | ٧                   |   |   |   |   |   | ٧ |   |    |    |    | ٧  |    |    |    |    |    |    |         |
| TDMD1 Rx              | ٧                   |   |   |   |   |   |   | ٧ |    |    |    |    | ٧  |    |    |    |    |    |         |
| TDMD1 Tx              | ٧                   |   |   |   |   |   |   |   | V  |    |    |    |    | ٧  |    |    |    |    |         |
| Time Stamp 1          |                     |   |   |   |   |   |   |   |    | ٧  | ٧  |    |    |    |    |    |    | ٧  | ٧       |
| Time Stamp 2          |                     |   |   |   |   |   |   |   |    | ٧  | ٧  |    |    |    |    |    |    | ٧  | ٧       |
| QUICC Engine<br>Timer |                     |   |   |   |   |   |   |   |    | V  | V  |    |    |    |    |    |    | ٧  | V       |
| QUICC Engine RTC      |                     |   |   |   |   | ٧ | ٧ |   |    |    |    |    | ٧  | ٧  | ٧  |    |    |    | ٧       |

The table below shows the clock routing options using the internal clock generators.

Table 22-5. Clock source options-internal clock

| Clock   |   | BRG clock number |   |   |   |   |   |    |    |  |  |  |  |  |
|---------|---|------------------|---|---|---|---|---|----|----|--|--|--|--|--|
|         | 1 | 2                | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |  |  |  |  |
| UCC1 Rx | V | V                |   |   | V | V |   |    |    |  |  |  |  |  |
| UCC1 Tx | V | V                |   |   | V | V |   |    |    |  |  |  |  |  |
| UCC3 Rx | V | V                |   |   | V | V |   |    |    |  |  |  |  |  |
| UCC3 Tx | V | V                |   |   | V | V |   |    |    |  |  |  |  |  |
| UCC5 Rx |   |                  | V | V | V | V |   |    |    |  |  |  |  |  |
| UCC5 Tx |   |                  | V | V | V | V |   |    |    |  |  |  |  |  |
| UCC7 Rx |   |                  | V | V | V | V |   |    |    |  |  |  |  |  |

Table 22-5. Clock source options-internal clock (continued)

| Clock              | BRG clock number |   |   |   |   |   |   |    |    |  |  |  |  |
|--------------------|------------------|---|---|---|---|---|---|----|----|--|--|--|--|
|                    | 1                | 2 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |  |  |  |
| UCC7 Tx            |                  |   | V | V | V | V |   |    |    |  |  |  |  |
| UPC1 Rx            |                  |   | V | V | V | V |   |    |    |  |  |  |  |
| UPC1 Tx            |                  |   | V | V | V | V |   |    |    |  |  |  |  |
| UPC1 IR            |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMA1 Rx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMA1 Tx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMB1 Rx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMB1 Tx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMC1 Rx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMC1 Tx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMD1 Rx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMD1 Tx           |                  |   |   |   |   |   |   |    |    |  |  |  |  |
| TDMA1 Rsync        |                  |   |   |   |   |   | V | V  |    |  |  |  |  |
| TDMA1 Tsync        |                  |   |   |   |   |   | V | V  |    |  |  |  |  |
| TDMB1 Rsync        |                  |   |   |   |   |   | V | V  |    |  |  |  |  |
| TDMB1 Tsync        |                  |   |   |   |   |   | V | V  |    |  |  |  |  |
| TDMC1 Rsync        |                  |   |   |   |   |   | V |    | V  |  |  |  |  |
| TDMC1 Tsync        |                  |   |   |   |   |   | V |    | V  |  |  |  |  |
| TDMD1 Rsync        |                  |   |   |   |   |   | V |    | V  |  |  |  |  |
| TDMD1 Tsync        |                  |   |   |   |   |   | V |    | V  |  |  |  |  |
| Time Stamp 1       |                  |   |   |   |   |   |   |    | V  |  |  |  |  |
| Time Stamp 2       |                  |   |   |   |   |   |   |    | V  |  |  |  |  |
| QUICC Engine Timer |                  |   |   |   |   |   |   |    | V  |  |  |  |  |
| QUICC Engine RTC   |                  |   |   |   |   |   |   |    |    |  |  |  |  |

The table below shows the UART autobaud clock options.

Table 22-6. Clock source options-UART autobaud clock options

| Clock   |   | BRG Clock Number for UART Autobaud |   |   |   |   |  |  |  |  |  |  |
|---------|---|------------------------------------|---|---|---|---|--|--|--|--|--|--|
|         | 1 | 2                                  | 5 | 6 | 7 | 8 |  |  |  |  |  |  |
| UCC1 Rx | V | V                                  |   |   |   |   |  |  |  |  |  |  |
| UCC1 Tx | V | V                                  |   |   |   |   |  |  |  |  |  |  |
| UCC3 Rx | V | V                                  |   |   |   |   |  |  |  |  |  |  |
| UCC3 Tx | V | V                                  |   |   |   |   |  |  |  |  |  |  |
| UCC5 Rx |   |                                    | V | V |   |   |  |  |  |  |  |  |
| UCC5 Tx |   |                                    | V | V |   |   |  |  |  |  |  |  |
| UCC7 Rx |   |                                    |   |   | V | V |  |  |  |  |  |  |
| UCC7 Tx |   |                                    |   |   | V | V |  |  |  |  |  |  |

## 22.3.3.2 Multiplexing and timers-CMX UCC clock route register (CMXUCR3)

The "CMX UCC Clock Route Register (CMXUCR3)" subsection does not apply.

## 22.3.3.3 Multiplexing and timers-baud-rate generators (BRGs), BRG configuration registers 1-16 (BRGCn)

The table below describes the BRGC*n* fields.

Table 22-7. BRGCn field descriptions

| Bits  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-13  | -    | Reserved, should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14    | RST  | Reset BRG. Performs a software reset of the BRG identical to that of an external reset. A reset disables the BRG and drives BRGO high. This is externally visible only if BRGO is connected to the corresponding parallel I/O pin.                                                                                                                                                                                                                      |
|       |      | 0 Enable the BRG.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |      | 1 Reset the BRG (software reset).                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15    | EN   | Enable BRG count. Used to dynamically stop the BRG from counting-useful for low-power modes.                                                                                                                                                                                                                                                                                                                                                            |
|       |      | 0 Stop all clocks to the BRG.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |      | 1 Enable clocks to the BRG.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 16-17 | EXTC | External clock source. Selects the BRG input clock.                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |      | 00 The BRG input clock comes from the BRGCLK (internal clock generated from the QUICC Engine clock, it is one-half of the QUICC Engine clock).                                                                                                                                                                                                                                                                                                          |
|       |      | 01 If BRG1, 2, 5, 6: The BRG input clock comes from the CLK3 pin.                                                                                                                                                                                                                                                                                                                                                                                       |
|       |      | If BRG7, 8: The BRG input clock comes from the CLK9 pin                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |      | If BRG9, 10: The BRG input clock comes from the CLK11 pin                                                                                                                                                                                                                                                                                                                                                                                               |
|       |      | If BRG11: The BRG input clock comes from the CLK13 pin                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |      | 10 If BRG1, 2, 5, 6: The BRG input clock comes from the CLK5 pin.                                                                                                                                                                                                                                                                                                                                                                                       |
|       |      | If BRG7, 8: The BRG input clock comes from the CLK15 pin                                                                                                                                                                                                                                                                                                                                                                                                |
|       |      | If BRG9, 10: The BRG input clock comes from the CLK21 pin                                                                                                                                                                                                                                                                                                                                                                                               |
|       |      | 11 Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 18    | ATB  | Autobaud. Selects autobaud operation of the BRG on the corresponding RXD. ATB must remain zero until the UCC receives the three Rx clocks. Then the user must set ATB to obtain the correct baud rate. After the baud rate is obtained and locked, it is indicated by setting AB in the UART event register, see "UCC UART Event Register (UCCE) and Mask Register (UCCM)," in <i>QUICC Engine™ Block Reference Manual with Protocol Interworking</i> . |
|       |      | 0 Normal operation of the BRG.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       |      | 1 When RXD goes low, the BRG determines the length of the start bit and synchronizes the BRG to the actual baud rate.                                                                                                                                                                                                                                                                                                                                   |

Table 22-7. BRGCn field descriptions (continued)

| Bits  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19-30 | CD    | Clock divider. CD presets an internal 12-bit counter that is decremented at the DIV16 output rate. When the counter reaches zero, it is reloaded with CD. CD = 0xFFF produces the minimum clock rate for BGRO (divide by 4,096); CD = 0x000 produces the maximum rate (divide by 1). When dividing by an odd number, the counter ensures a 50% duty cycle by asserting the terminal count; once on clock low and next on clock high. The terminal count signals that the counter has expired and then toggles the clock. |
|       |       | 0x000 Divide by 1 (maximum clock rate)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |       | 0x001 Divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       |       | 0xFFF Divide by 4096 (minimum clock rate)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31    | DIV16 | Divide-by-16. Selects a divide-by-1 or divide-by-16 prescaler before reaching the clock divider.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |       | 0 Divide by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |       | 1 Divide by 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

The table below shows the possible external clock sources for the BRGs.

Table 22-8. BRG external clock source options

| BRG   |   | CLK |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |
|-------|---|-----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|
|       | 1 | 3   | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 19 | 20 | 21 |
| BRG1  |   | V   |   | V |   |   |   |   |    |    |    |    |    |    |    |    |    |    |
| BRG2  |   | V   |   | ٧ |   |   |   |   |    |    |    |    |    |    |    |    |    |    |
| BRG5  |   | V   |   | V |   |   |   |   |    |    |    |    |    |    |    |    |    |    |
| BRG6  |   | V   |   | V |   |   |   |   |    |    |    |    |    |    |    |    |    |    |
| BRG7  |   |     |   |   |   |   |   | ٧ |    |    |    |    |    | V  |    |    |    |    |
| BRG8  |   |     |   |   |   |   |   | ٧ |    |    |    |    |    | ٧  |    |    |    |    |
| BRG9  |   |     |   |   |   |   |   |   |    | V  |    |    |    |    |    |    |    | ٧  |
| BRG10 |   |     |   |   |   |   |   |   |    | ٧  |    |    |    |    |    |    |    | ٧  |
| BRG11 |   |     |   |   |   |   |   |   |    |    |    | ٧  |    |    |    |    |    |    |

### 22.3.4 Unified communications controllers (UCCs)

Of the UCCs, only UCC1, UCC3, UCC5, and UCC7 are supported.

The following features are not supported: USB, MCC, SPI2, Ethernet TBI mode.

## 22.3.4.1 Unified communications controllers (UCCs)-UCC page base address

Refer to the table below for the UCC base addresses.

Table 22-9. Parameter RAM-UCC default base addresses

| Page | Address <sup>1</sup> | Peripheral | Size (Bytes) |
|------|----------------------|------------|--------------|
| 1    | 0x3400               | UCC1       | 256          |
| 3    | 0x3600               | UCC3       | 256          |
| 5    | 0x3000               | UCC5       | 256          |
| 7    | 0x3200               | UCC7       | 256          |

<sup>1.</sup> Offset from RAM\_Base

#### 22.3.5 UCC for fast protocols

Only a system bus is supported; references to a secondary bus should be disregarded.

As such,

• In the "Bus Mode Registers (RBMR and TBMR)" subsection of the QEIWRM, DTB and BDB should be reserved.

#### 22.3.6 UCC Ethernet controller (UEC)

The device only supports UCC1, UCC3, UCC5, and UCC7.

Ethernet TBI mode is not supported, and all references to it should be disregarded, which includes the following:

- In the "UCC Protocol Specific Ethernet Mode Register (UPSMR)" section, the TBIM bit is not available and should be reserved.
- The "UCC Ten Bit Interface Physical Address Register (UTBIPAR)" section should be disregarded and offset 0x154 should be considered reserved in the memory map.

## 22.3.6.1 UCC Ethernet controller (UEC)-init Tx, init Rx, and init Tx and Rx parameters command

In the "InitEnet Command Parameter" table, RGF and TGF multithread options greater than two are not available and should be reserved.

In addition, in the RISC Allocation field, only 0001 is valid and all others are reserved.

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### 22.3.6.2 UCC Ethernet controller (UEC)-multiuser RAM usage

The table columns "Example for Gigabit Ethernet" and "Gigabit Ethernet Example" should be disregarded for all tables.

#### 22.3.7 IEEE standard 1588 assist

The QUICC Engine IEEE Std. 1588 does not support the BRG internal clock mode of operation, so all references to it should be disregarded.

#### 22.3.8 UTOPIA POS bus controller (UPC)

This device does not support POS-PHY.

#### 22.3.9 ATM controller AAL0, AAL1, and AAL5

This device does not support ATM AAL1.

#### 22.3.10 HDLC controller

The ratio between the HDLC interface serial clock frequency and the QUICC Engine clock frequency should be at least 1:3.

#### **NOTE**

The HDLC serial clock must not exceed the maximal frequency as specified in the *P1021 QorIQ Integrated Processor Hardware Specifications*.

#### 22.3.10.1 HDLC controller-introduction

It should be noted that GUMR[RTSM] should be set for the HDLC nibble mode.

#### 22.3.11 Transparent controller

The does not support the automatic sync feature, so all references to it should be disregarded.

The transparent protocol is supported on all UCCs, but octal mode is not supported. UCC1 and UCC7 only support 1-bit data (serial) mode, while UCC3 and UCC5 only support 1- and 4-bit data modes only.

#### 22.3.12 UCC for slow protocols

Only a system bus is supported; references to a secondary bus should be disregarded. As such.

• In the "Bus Mode Registers (RBMR and TBMR)" subsection of the QEIWRM, DTB and BDB should be reserved.

#### 22.3.13 Serial peripheral interface (SPI)

Only a system bus is supported; references to a secondary bus should be disregarded. As such,

• In the "Receive/Transmit Bus Mode Registers" subsection, DTB should be reserved.

#### **22.3.14 BISYNC mode**

The ratio between the BISYNC serial clock frequency and the QUICC Engine clock frequency should be at least 1:7..

Generally, the BISYNC serial frequency is less than 20 MHz.

#### 22.3.15 Serial interface with time-slot assigner

Of the four TDMs-TDMA, TDMB, TDMC, TDMD-TDMA and TDMD only support 1-bit data (serial) mode, while TDMB and TDMC can support both 1- and 4-bit data modes.

#### QUICC engine implementation details

The TDM can only work with an external sync and external clock; other options are not supported. The external clock and external sync need to meet the timing specifications as provided in the *P1021 QorIQ Integrated Processor Hardware Specifications*.

This device supports TDM in a high-speed mode. To run in this mode, the QUICC Engine platform to TDM interface frequency ratio should be 8:1, where a ratio of 400 MHz: 50 MHz is recommended. The TDM maximum frequency is 50 MHz.

For the ISDN protocol, the maximum frequency supported is 25 MHz, with the condition that the QUICC Engine platform to ISDN interface frequency ratio is 16:1. For example, if the QUICC Engine platform frequency is 400 MHz, then the ISDN interface maximum frequency is 25 MHz.

#### 22.3.16 Serial ATM microcode

A multi-channel controller (MCC) is not supported; references to MCC should be disregarded.

Only a system bus is supported; references to a secondary bus should be disregarded. As such,

- In the "MTC Interrupt Queue SDMA Control" subsection, BIB should be reserved.
- In the "IMA Root Table SAM Programming" subsection, IQB and DSB should be reserved.

#### 22.3.17 Inverse multiplexing for ATM (IMA)

Only a system bus is supported; references to a secondary bus should be disregarded.

As such,

- In the "IMA Control (IMACNTL)" subsection, IQB and DSB should be reserved.
- In the "Data Structure Organization" and "Structures in External Memory" subsection, the structures may reside on the CSB bus.

# **Appendix A Terminology, Conventions, and Resources**

This appendix defines conventions used throughout the document.

#### A.1 About this content

The primary objective of this document is to define the functionality of *P1021*. *P1021* provides integration of processing power for networking and communications peripherals, resulting in higher device performance. It contains a e500 v2 processor core. The *e500 v2* processor core is a low-power implementation of the family of reduced instruction set computing (RISC) embedded processors that implement the embedded category features of the Power Architecture technology.

#### NOTE

The diagrams in this content are provided to aid in understanding the overall functionality and features of this product. They do not depict the implementation details of the product, which are subject to change.

### A.2 Acronyms and abbreviations

This table describes commonly-used acronyms and abbreviations used in this document.

Table A-1. Acronyms and abbreviations

| Acronym/<br>Abbreviation | Meaning                      |
|--------------------------|------------------------------|
| 8b/10b                   | 8-bit/10-bit encoding        |
| AIC                      | Antenna interface controller |
| AMC                      | Advanced mezzanine card      |
| ATM                      | Asynchronous transfer mode   |

Table A-1. Acronyms and abbreviations (continued)

| Acronym/<br>Abbreviation | Meaning                                             |
|--------------------------|-----------------------------------------------------|
| ATMU                     | Address translation and mapping unit                |
| BD                       | Buffer descriptor                                   |
| ВТВ                      | Branch target buffer                                |
| BUID                     | Bus unit ID                                         |
| CAM                      | Content-addressable memory                          |
| ССВ                      | Core complex bus                                    |
| CCF                      | coreNet coherence fabric                            |
| CCSR                     | Configuration control and status register           |
| CLASS                    | Chip-level arbitration and switching system         |
| CRC                      | Cyclic redundancy check                             |
| DCSR                     | Debug configuration and status register             |
| DDR                      | Double data-rate                                    |
| DIP                      | Dual inline package                                 |
| DPLL                     | Digital phase-locked loop                           |
| DTLB                     | Data translation lookaside buffer                   |
| dTSEC                    | Data path three-speed Ethernet controller           |
| DUART                    | Dual universal asynchronous receiver/transmitter    |
| ECC                      | Error checking and correction                       |
| ECM                      | e500 coherency module                               |
| EEST                     | Enhanced Ethernet serial transceiver                |
| EHCI                     | Enhanced host controller interface                  |
| eLBC                     | Enhanced local bus controller                       |
| EPROM                    | Erasable programmable read-only memory              |
| EEPROM                   | Electrically-erasable programmable read-only memory |
| eTSEC                    | Enhanced three-speed Ethernet controller            |
| FCS                      | Frame-check sequence                                |
| FIFO                     | First in, first out                                 |
| GCI                      | General circuit interface                           |
| GMII                     | Gigabit media-independent interface                 |
| GPCM                     | General-purpose chip-select machine                 |
| GPIO                     | General-purpose I/O                                 |
| GPR                      | General-purpose register                            |
| I2C                      | Inter-integrated circuit                            |
| IFC                      | Intergrated Flash controller                        |
| IPG                      | Interpacket gap                                     |
| IrDA                     | Infrared Data Association                           |
| ISDN                     | Integrated services digital network                 |
| ITLB                     | Instruction translation lookaside buffer            |
| IU                       | Integer unit                                        |

Table A-1. Acronyms and abbreviations (continued)

| Acronym/<br>Abbreviation | Meaning                                     |
|--------------------------|---------------------------------------------|
| HSSI                     | High-speed serial interface                 |
| LAE                      | Local access error                          |
| LAW                      | Local access window                         |
| LBC                      | Local bus controller                        |
| LIFO                     | Last-in-first-out                           |
| LRU                      | Least recently used                         |
| LSB                      | Least significant byte                      |
| Isb                      | Least significant bit                       |
| LSU                      | Load/store unit                             |
| MAC                      | Multiply accumulate, media access control   |
| MDI                      | Medium-dependent interface                  |
| MII                      | Media independent interface                 |
| MMU                      | Memory management unit                      |
| MSB                      | Most significant byte                       |
| msb                      | Most significant bit                        |
| NMI                      | Non-maskable interrupt                      |
| NMSI                     | Nonmultiplexed serial interface             |
| No-op                    | No operation                                |
| OCeaN                    | On-chip network                             |
| ОС                       |                                             |
| OSI                      | Open systems interconnection                |
| PCS                      | Physical coding sublayer                    |
| PIC                      | Programmable interrupt controller           |
| РМА                      | Physical medium attachment                  |
| PMD                      | Physical medium dependent                   |
| PLL                      | Phase-locked loop                           |
| POR                      | Power-on reset                              |
| PRI                      | Primary rate interface                      |
| PWM                      | Pulse-width modulation                      |
| RAID                     | Redundant array of independent drives       |
| RGMII                    | Reduced gigabit media-independent interface |
| RIO                      | RapidIO                                     |
| RTOS                     | Real-time operating system                  |
| RWITM                    | Read with intent to modify                  |
| RMW                      | Read-modify-write                           |
| Rx                       | Receiver                                    |
| RxBD                     | Receive buffer descriptor                   |
| SATA                     | Serial advanced technology attachment       |
| SCP                      | Serial control port                         |

Table A-1. Acronyms and abbreviations (continued)

| Acronym/<br>Abbreviation | Meaning                                     |
|--------------------------|---------------------------------------------|
| SDLC                     | Synchronous data link control               |
| SDMA                     | Serial DMA                                  |
| SD/MMC                   | Secure digital/multimedia card              |
| SDOS                     | SmartDSP operating system                   |
| SEC                      | Security Engine                             |
| SerDes                   | Serializer/Deserializer                     |
| SFD                      | Start frame delimiter                       |
| SGMII                    | Serial gigabit media-independent interface  |
| SI                       | Serial interface                            |
| SIU                      | System interface unit                       |
| SMC                      | Serial management controller                |
| SPI                      | Serial peripheral interface                 |
| SPR                      | Special-purpose register                    |
| SRAM                     | Static random access memory                 |
| TAP                      | Test access port                            |
| ТВІ                      | Ten-bit interface                           |
| TDM                      | Time-division multiplexed                   |
| TLB                      | Translation lookaside buffer                |
| TSA                      | Time-slot assigner                          |
| Tx                       | Transmitter                                 |
| TxBD                     | Transmit buffer descriptor                  |
| UART                     | Universal asynchronous receiver/transmitter |
| UPM                      | User-programmable machine                   |
| uTCA                     | Micro telecommunications computing platform |
| UTP                      | Unshielded twisted pair                     |
| VA                       | Virtual address                             |
| ZBT                      | Zero bus turnaround                         |

### A.3 Notational conventions

This table shows notational conventions used in this content.

**Table A-2. Notational conventions** 

| Convention Definition                                              |  |
|--------------------------------------------------------------------|--|
| General                                                            |  |
| Cleared When a bit takes the value zero, it is said to be cleared. |  |

Table A-2. Notational conventions (continued)

| Convention          | Definition                                                                                                                                                                                                    |  |  |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Set                 | When a bit takes the value one, it is said to be set.                                                                                                                                                         |  |  |
| mnemonics           | Instruction mnemonics are shown in lowercase bold.                                                                                                                                                            |  |  |
| italics             | Italics can indicate the following:                                                                                                                                                                           |  |  |
|                     | <ul> <li>Variable command parameters, for example, bcctrx</li> <li>Titles of publications</li> <li>Internal signals, for example, core int</li> </ul>                                                         |  |  |
| 0x                  | Prefix to denote hexadecimal number                                                                                                                                                                           |  |  |
| h                   | Suffix to denote hexadecimal number                                                                                                                                                                           |  |  |
| 0b                  | Prefix to denote binary number                                                                                                                                                                                |  |  |
| b                   | Suffix to denote binary number                                                                                                                                                                                |  |  |
| rA, rB              | Instruction syntax used to identify a source GPR                                                                                                                                                              |  |  |
| rD                  | Instruction syntax used to identify a destination GPR                                                                                                                                                         |  |  |
| REGISTER[FIELD]     | Abbreviations for registers are shown in uppercase text. Specific bits, fields, or ranges appear in brackets. For example, MSR[LE] refers to the little-endian mode enable bit in the machine state register. |  |  |
| х                   | In some contexts, such as signal encodings, an unitalicized x indicates a don't care.                                                                                                                         |  |  |
| X                   | An italicized x indicates an alphanumeric variable                                                                                                                                                            |  |  |
| n                   | An italicized <i>n</i> indicates either:  • An integer variable                                                                                                                                               |  |  |
|                     | A general-purpose bitfield unknown                                                                                                                                                                            |  |  |
| ¬                   | NOT logical operator                                                                                                                                                                                          |  |  |
| &                   | AND logical operator                                                                                                                                                                                          |  |  |
| 1                   | OR logical operator                                                                                                                                                                                           |  |  |
| II                  | Concatenation, for example, TCR[WPEXT] II TCR[WP]                                                                                                                                                             |  |  |
| Signals             |                                                                                                                                                                                                               |  |  |
| OVERBAR             | An overbar indicates that a signal is active-low.                                                                                                                                                             |  |  |
| lowercase_italics   | Lowercase italics is used to indicate internal signals                                                                                                                                                        |  |  |
| lowercase_plaintext | Lowercase plain text is used to indicate signals that are used for configuration.                                                                                                                             |  |  |
| Register access     | Register access                                                                                                                                                                                               |  |  |
| Reserved            | Ignored for the purposes of determining access type                                                                                                                                                           |  |  |
| R/W                 | Indicates that all non-reserved fields in a register are read/write                                                                                                                                           |  |  |
| R                   | Indicates that all non-reserved fields in a register are read only                                                                                                                                            |  |  |
| W                   | Indicates that all non-reserved fields in a register are write only                                                                                                                                           |  |  |
| w1c                 | Indicates that all non-reserved fields in a register are cleared by writing ones to them                                                                                                                      |  |  |

#### A.4 Related resources

This table shows related resources that may be helpful. Additional literature is published as new processors become available. For current literature, visit www.freescale.com or contact your local FAE.

#### P1021 QorlQ Integrated Processor Reference Manual, Rev. 6, 01/2013

#### Table A-3. Related resources

| Resource              | Purpose                                                                                                                                       |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| P1021EC               | Provides specific data regarding bus timing, signal behavior, and AC, DC, and thermal characteristics, as well as other design considerations |
| <i>EB748</i> , Rev 0. | Provides specific details of security engine (SEC 3.3.2).                                                                                     |

## Appendix B P1012 –A Single Core Version

The P1021 is also available in a single core version known as the P1012.

#### **B.1** Overview

The P1021 is also available in a single core version known as the P1012 and shown in the figure below.



Figure B-1. P1012 Block Diagram

# Appendix C Substantive changes from revision 5 to revision 6

This appendix contains the revision history for P1021.

## **C.1 Overview Revision History**

| Reference                               | Description                                                                                                        |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Enhanced secure digital host controller | Removed reference to SDIO card.                                                                                    |
|                                         | Removed the following listed item: Supports SDIO read wait and suspend/resume operations                           |
| Chip-level features                     | Replaced "IEEE 1588 support (not supported for SGMII 10/100 mode)" with "IEEE 1588 support".                       |
| QUICC engine subsystem                  | In the list item "HDLC and Transparent controllers up to", updated the HDLC frequency from "70 Mbps" to "50 Mbps". |
| PCI Express interfaces                  | Corrected the measuring unit of PCI Express data rate from Gbps to GT/s.                                           |

### **C.2** Memory Map Revision History

| Reference                          | Description         |
|------------------------------------|---------------------|
| Precedence of local access windows | Added this section. |

## **C.3** Signal Descriptions Revision History

| Reference        | Description                      |
|------------------|----------------------------------|
| Signals overview | Removed reference to SDIO cards. |
| Signals overview | Added IRQ6 pin.                  |

#### Reset, Clocking, and Initialization Revision History

| Reference                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ports Tables               | In Table 3-8, SPI1_SPISEL pin selection is added against CE_PB20.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Ports Tables  Ports Tables | <ul> <li>In Table 3-8, SPI1_SPISEL pin selection is added against CE_PB20.</li> <li>Updated Table 3-10</li> <li>Reordered columns (Placed "QUICC Engine Signal" first so that table data is primarily indexed by QUICC Engine signal name)</li> <li>Reordered rows by QUICC Engine signal name; add port group separation rows</li> <li>Segregated CLK-related information into a separate column</li> <li>Added columns for GPIO, CLK, and BRG</li> <li>Added column for "Alternate Function"</li> <li>Grouped QUICC Engine subfunctional columns in title row</li> <li>For CE_PA29, replaced Default Function "CE_PA29" with "CFG_DDR_DEBUG."</li> </ul>        |
|                            | <ul> <li>For CE_PB2, designated Alternate Function and Mux Control Bit (PMUXCR) as "none." (Formerly, PMUXCR bit stated "QE0.")</li> <li>For CE_PB3, designated Alternate Function and Mux Control Bit (PMUXCR) as "none." (Formerly, PMUXCR bit stated "QE0.")</li> <li>For CE_PB10, replaced Default Function "CE_PB10" with "IRQ6."</li> <li>For CE_PB18, replaced Default Function "CE_PB18" with "—."</li> <li>For CE_PB19, replaced Default Function "CE_PB19" with "CFG_MEM_DEBUG."</li> <li>For CE_PB19, replaced ENET1/ENET5 function "MDC" with "CE_MUX_MDC."</li> <li>For CE_PB20, replaced ENET1/ENET5 function "MDIO" with "CE_MUX_MDIO."</li> </ul> |
| Signals overview           | Removed signals PLL_PER_OUT[0:3], PLL_UP_DN, LB_MDVAL, and LB_MSRCID.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Table 3-3                  | Added the Output Signal States During Reset table.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Signals overview           | Removed references to TSEC1_RXD[7:4].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## C.4 Reset, Clocking, and Initialization Revision History

| Reference               | Description                                                                                                                                                |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EEPROM data structure   | For 0x68–0x6B Address, changed the Data bits [0-31] from:                                                                                                  |
|                         | "Must be = 1024 (but is recommended to be as small as possible)"                                                                                           |
|                         | to                                                                                                                                                         |
|                         | "Must be $1 = N = 1024$ (but is recommended to be as small as possible)".                                                                                  |
| Power-on reset sequence | Removed the note "Except cfg_dram_type which should be driven before HRESET" in the Figure 4-5.                                                            |
| DDR PLL ratio           | Updated the second sentence from:                                                                                                                          |
|                         | "The DDR complex clock drives the DDR data rate, which is twice the rate at which commands are issued on the DDR interface when DDR clock select is zero." |
|                         | to                                                                                                                                                         |
|                         | "The DDR complex clock drives the DDR data rate, which is twice the rate at which commands are issued on the DDR interface."                               |

#### Appendix C Substantive changes from revision 5 to revision 6

| Reference                                                 | Description                                                                                                                                       |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| System clock and DDR controller complex                   | Updated the fourth sentence in the first paragraph from:                                                                                          |
| clock                                                     | "The CCB clock also feeds the PLLs in the e500 cores and the PLL that create clocks for the local bus memory controller."                         |
|                                                           | to                                                                                                                                                |
|                                                           | "The CCB clock also feeds the PLLs in the e500 cores."                                                                                            |
| , Figure 4-6                                              | In the clock system block diagram, updated the range of LCLK[0:1] from 10-100 MHz to 10-83 MHz.                                                   |
| eSDHC controller initial configuration                    | Updated the first sentence of the fourth bulleted list as:                                                                                        |
|                                                           | SDCLK at 400 kHz or below, but higher than 100 kHz (for platform frequency up to 400 MHz, and therefore eSDHC base clock frequency up to 200 MHz) |
| Alternate configuration attribute register (reset_ALTCAR) | In reset_ALTCAR[TRGT_ID], updated bit setting 1000 from "Configuration, control, status registers" to "Reserved".                                 |
| eSDHC boot features                                       | Updated the MMC version from 4.0 to 4.2.                                                                                                          |
| DDR speed                                                 | Updated the DDR data rate from 500 Mbps to 500 MT/s.                                                                                              |

## C.5 e500 Core Integration Details Revision History

| Reference                           | Description                                                                                                                                    |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Summary of core integration details | In the second row of 'HID1Implementation' description, updated 'ERR_INT_EN[MBEE] must be zero' as 'ERR_INT_EN[MBEE] must be set'.              |
| Table 5-1                           | Deleted the last two sentences of QorlQ implementation of the TCR (timer control register) feature, and added the following sentences instead: |
|                                     | 10 Second timeout generates HRESET_REQ output externally                                                                                       |
|                                     | 11 Second timeout automatically resets the given processor core                                                                                |
| Table 5-1                           | Updated 01 for TCR (timer control register).                                                                                                   |

## **C.6 DDR Memory Controllers Revision History**

| Reference                                             | Description                                                                                                     |
|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Memory data path read capture ECC (DDR_CAPTURE_ECC)   | Updated the description for DDR_CAPTURE_ECC[ECE] bit.                                                           |
| - DDR SDRAM control configuration (DDR_DDR_SDRAM_CFG) | In DDR_SDRAM_CFG[ECC_EN] description, updated 'ERR_INT_EN[MBEE] must be zero' to 'ERR_INT_EN[MBEE] must be set' |

#### **DDR Memory Controllers Revision History**

| Reference                                               | Description                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single-Bit ECC memory error                             | Modified the ERR_SBE[SBEC] description to:                                                                                                                                                                                                                                                                                                                                                 |
| management (DDR_ERR_SBE)                                | "Single-bit error counter. Indicates the number of single-bit errors detected and corrected since the last error report. If single-bit error reporting is enabled, an error is reported and a regular or critical interrupt is generated when this value equals SBET. SBEC is automatically cleared when the threshold value is reached."                                                  |
| Memory error disable                                    | Changed the sentence in the ERR_DISABLE[MBED] description from:                                                                                                                                                                                                                                                                                                                            |
| (DDR_ERR_DISABLE)                                       | "If RFXE is zero and this error occurs, MBED and ERR_INT_EN[MBEE] must be zero and ECC_EN must be one to ensure that an interrupt is generated"                                                                                                                                                                                                                                            |
|                                                         | to                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                         | "If RFXE is zero and this error occurs, ERR_DISABLE[MBED] must be zero and ERR_INT_EN[MBEE] and ECC_EN must be one to ensure that an interrupt is generated".                                                                                                                                                                                                                              |
| Memory error interrupt enable                           | Changed the sentence in the ERR_INT_EN[MBEE] description from:                                                                                                                                                                                                                                                                                                                             |
| (DDR_ERR_INT_EN)                                        | "If RFXE is zero and this error occurs, MBEE and ERR_DISABLE[MBED] must be zero and DDR_SDRAM_CFG[ECC_EN] must be set to ensure that an interrupt is generated"                                                                                                                                                                                                                            |
|                                                         | to                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                         | "If RFXE is zero and this error occurs, ERR_DISABLE[MBED] must be zero and ERR_INT_EN[MBEE] and ECC_EN must be one to ensure that an interrupt is generated".                                                                                                                                                                                                                              |
| Table 8-71                                              | Added the following action for the Single-bit ECC Threshold error:                                                                                                                                                                                                                                                                                                                         |
|                                                         | "Regular or critical interrupt if enabled."                                                                                                                                                                                                                                                                                                                                                |
| Supported DDR SDRAM organizations                       | Added the last two rows for 8 GB SDRAM Device configuration.                                                                                                                                                                                                                                                                                                                               |
| Table 8-71                                              | Removed "Regular or critical interrupt if enabled" from (Notification category) Action column and updated it same as for 'Access Error'.                                                                                                                                                                                                                                                   |
| Error management                                        | In the first sentence of the third paragraph, updated "machine check or critical interrupt" as "interrupt".                                                                                                                                                                                                                                                                                |
| DDR SDRAM mode control                                  | Added the following sentences to the register description:                                                                                                                                                                                                                                                                                                                                 |
| (DDR_DDR_SDRAM_MD_CNTL)                                 | Before issuing a command via the DDR_SDRAM_MD_CNTL register, the DDR interface should be idle. This can be done by setting DDR_SDRAM_CFG[MEM_HALT] and disabling refreshes by clearing DDR_INTERVAL[REFINT]. If there are memory contents that need to be preserved during this time, then software should also force any required refresh commands while DDR_INTERVAL[REFINT] is cleared. |
| DDR SDRAM interface operation                           | Updated the last two sentences of the second paragraph".                                                                                                                                                                                                                                                                                                                                   |
| DDR SDRAM interface timing                              | Removed the following sentence from second paragraph: ", except for CASLAT which can be programmed with 1/2 clock granularity."                                                                                                                                                                                                                                                            |
| Error management                                        | In the table "Memory controller errors," updated the action column for Single-bit ECC threshold, Multi-bit ECC error and Memory select error.                                                                                                                                                                                                                                              |
| Memory interface signals                                | Updated MRAS_B, MCAS_B, and MWE_B signals in "Timings" to state that this signal is tri-stated when memory controller is idle.                                                                                                                                                                                                                                                             |
| Self-refresh in sleep mode                              | Added note: Deep sleep mode is not supported for DDR3 registered DIMMS.                                                                                                                                                                                                                                                                                                                    |
| DDR training initialization address (DDR_DDR_INIT_ADDR) | Updated the second note as "this address should be written to using a 32-byte transaction to avoid possible ECC errors."                                                                                                                                                                                                                                                                   |

| Reference                                                                                                                                                                                                                       | Description                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signals overview                                                                                                                                                                                                                | - Removed bullet for "Debug Signals".                                                                                                                                                                                               |
|                                                                                                                                                                                                                                 | - Removed rows for MDVAL and MSRCID signals from Table 8-1                                                                                                                                                                          |
|                                                                                                                                                                                                                                 | - Removed section "Debug Signals".                                                                                                                                                                                                  |
| DDR training initialization address (DDR_DDR_INIT_ADDR)                                                                                                                                                                         | In the second note, changed from "this address should be written to using an 8-or 32-byte transaction to avoid possible ECC errors" to "this address should be written to using a 32-byte transaction to avoid possible ECC errors" |
| DDR Control Driver Register 1 (DDR_DDRCDR_1)                                                                                                                                                                                    | Removed the legal impedance values list and added the "Valid Impedance Override Values" table consisting of these values in place.                                                                                                  |
| Using Forced Self-Refresh Mode to<br>Implement a Battery-Backed RAM<br>System, Hardware Based Self-Refresh<br>Scheme, Software Based Self-Refresh<br>Scheme, and Bypassing Re-initialization<br>During Battery-Backed Operation | Added these sections.                                                                                                                                                                                                               |
| Error management                                                                                                                                                                                                                | Removed ", and transfer error acknowledge (TEA) is asserted internally on the CCB bus (if enabled, as described in Memory error disable (DDR_ERR_DISABLE) (view resource))" from the first sentence of the fourth paragraph.        |

## C.7 Programmable Interrupt Controller (PIC) Revision History

| Reference                                                                                                                                                                                                                                         | Description                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Shared message signaled interrupt destination register n (PIC_MSIDRn)                                                                                                                                                                             | Updated bit 0 as reserved.                                                                                                                                                                             |
| throughout                                                                                                                                                                                                                                        | Added IRQ6 support.                                                                                                                                                                                    |
| Shared message signaled interrupt                                                                                                                                                                                                                 | Added the following note:                                                                                                                                                                              |
| register n (PIC_MSIRn)                                                                                                                                                                                                                            | Note: After soft reset, read the MSIRs to ensure that any interrupts previously pending are cleared                                                                                                    |
| Message enable register (PIC_MERa) and Message status register (PIC_MSRa)                                                                                                                                                                         | Added PIC_MERa and PIC_MSRa registers at 0004_2500 and 0004_2510 offsets.                                                                                                                              |
| Processor core 1 who am I register (PIC_WHOAMI_CPU1)                                                                                                                                                                                              | Updated reset value from 0000_0000 to 0000_00nn.                                                                                                                                                       |
| Feature reporting register (PIC_FRR)                                                                                                                                                                                                              | Added note for the reset value of NCPU bit field.                                                                                                                                                      |
| Processor core 1 current task priority register (PIC_CTPR_CPU1), Processor core 1 who am I register (PIC_WHOAMI_CPU1), Processor core 1 interrupt acknowledge register (PIC_IACK_CPU1), Processor core 1 end of interrupt register (PIC_EOI_CPU1) | Added missing registers.                                                                                                                                                                               |
| Table 9-1                                                                                                                                                                                                                                         | Deleted the line "core_hreset_req can also be caused by a second timer timeout condition as described in "Timer Control Registers (TCRA-TCRB)" in the Sources column of the Reset core interrupt type. |
| Introduction                                                                                                                                                                                                                                      | Updated the last sentence of the second paragraph.                                                                                                                                                     |

#### **Enhanced Local Bus Controller (eLBC) Revision History**

| Reference                          | Description                                                                                                                                                                      |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Overview                           | Added "signal IRQ_OUT_B." towards the end of the second last bullet.                                                                                                             |
| Interrupt destinations             | Added a note below table "PCI Express INTx/IRQn sharing" regarding IRQ and GPIO multiplexing.                                                                                    |
| Table 9-3                          | Added table "ORed Error Interrupt Sources"                                                                                                                                       |
| PIC memory map/register definition | Updated regiter names for PIC_IPIDRn (offsets 4_0040, 4_0050, 4_0060, 4_0070), PIC_CTPR (4_0080), PIC_WHOAMI (offset 4_0090), PIC_IACK (offset 4_00A0), PIC_EOI (offset 4_00B0). |

## C.8 Enhanced Local Bus Controller (eLBC) Revision History

| Reference                                                                                                 | Description                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External access termination (LGTA_B)                                                                      | In the first paragraph, changed "LGTA should be asserted for at least one bus cycle to be effective" to "LGTA must be asserted for two bus cycles to be effective."                                                                                                                                             |
| General-purpose chip-select machine (GPCM)                                                                | Added elbc_plll_bypass tag to the GPCM basic read timing with PLL bypass figure                                                                                                                                                                                                                                 |
| Features                                                                                                  | Updated the bulleted item "26-bit address decoding with mask" to "32-bit address decoding with mask.                                                                                                                                                                                                            |
| eLBC external signal descriptions                                                                         | In Table 12-1, specified the range for LA signals as LA[16:31] and specified the number of signals as 16.                                                                                                                                                                                                       |
| Configuration register (eLBC_LBCR)                                                                        | Updated the bit setting for LBCR[AHD] =0 as follows:                                                                                                                                                                                                                                                            |
|                                                                                                           | During address phases on the local bus, the LALE signal negates one platform clock period prior to the address being invalidated. For instance, at 333 MHz, this provides 3 ns of additional address hold time at the external address latch. Running the platform at a lower frequency improves the hold time. |
| Configuration register (eLBC_LBCR)                                                                        | Updated the bit setting for LBCR[AS16] = 1 as follows:                                                                                                                                                                                                                                                          |
|                                                                                                           | Same address bit assignment as AS16 = 0 for 32-bit port sizes. However, for port sizes smaller than 32 bits, the least-significant address bits (1:10) are driven on LA[22:31], rest 16 bits of the valid 26-bit memory address are driven on LAD[0:15].                                                        |
| Clock ratio register (eLBC_LCRR)                                                                          | Removed the note given for LCRR[0:13] bits.                                                                                                                                                                                                                                                                     |
| Options register 0 layout for FCM Mode (eLBC_ORf0) and Options register 0 layout for UPM Mode (eLBC_ORu0) | Updated the reset values of Options register 0 layout for FCM Mode (ORf0) and Options register 0 layout for UPM Mode (ORu0).                                                                                                                                                                                    |
| Figure 12-111                                                                                             | Added the figure.                                                                                                                                                                                                                                                                                               |
| External address latch enable signal (LALE)                                                               | Removed the paragraph "If the RCW is loaded by the eLBC, LALE may remain at an unknown value for up to 8 cycles after PORESET negation. Thus, LALE should"                                                                                                                                                      |
| Table 12-198                                                                                              | For OR0 register field SCY, changed the settings from "From por_cfg_scy[1:3]" to "010."                                                                                                                                                                                                                         |
| External address latch enable signal (LALE)                                                               | Removed the second last paragraph starting "If the RCW is loaded by the eLBC, LALE"                                                                                                                                                                                                                             |
| eLBC external signal descriptions                                                                         | In the Name column, added LGTA_B in the "LGPL4/LFRB_B/LUPWAIT/LPBSE" group.                                                                                                                                                                                                                                     |

#### Appendix C Substantive changes from revision 5 to revision 6

| Reference                            | Description                                                                        |
|--------------------------------------|------------------------------------------------------------------------------------|
| Table 12-207                         | Added commands FMR and LSOR to the table.                                          |
| External access termination (LGTA_B) | Updated Figure 12-83 :                                                             |
|                                      | - Removed the first (the upper one) LCLK clock signal                              |
|                                      | - Updated "Sample point" as "Sample point for LGTA signal"                         |
| Figure 12-71                         | Removed t <sub>LSKEW</sub> from figure and updated LCLK to start from rising edge. |
| eLBC external signal descriptions    | Removed all instances of MDVAL and MSRCID debug signals.                           |
| Configuration register (eLBC_LBCR)   | Updated the ABSWP and AS16 bit description for 16-bit port size.                   |

## **C.9 DMA Controller Revision History**

| Reference                                                  | Description                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA current list descriptor address register (DMA_CLSDARn) | Updated the name of DMA <i>n</i> current list descriptor address register (DMA <i>x</i> _CLSDAR <i>n</i> ). It was mislabeled in the last revision.                                                                                                                                             |
| DMA channel operation                                      | Updated the second sentence of the first paragraph as follows:                                                                                                                                                                                                                                  |
|                                                            | In both modes, a channel can be activated by clearing and setting MRn[CS], or through the single-write start mode using MRn[CDSM/SWSM] and MRn[SRW], or through an external control mode using MRn[ECS_EN] and the external DMA_DREQ signal.                                                    |
| DMA transfer interfaces                                    | Updated section description.                                                                                                                                                                                                                                                                    |
| Table 13-3                                                 | Modified the introductory text to the following:                                                                                                                                                                                                                                                |
|                                                            | This table describes the external DMA control signals. These signals are only utilized when operating in external master mode. See External control mode transfer.                                                                                                                              |
| DMA mode register (DMA_MRn)                                | In the bifield description for DMAx_MRn[XFE], changed "the new chaining features," to, "striding feature in direct mode or disable list chaining feature in chaining mode"                                                                                                                      |
| Basic chaining, single-write start mode                    | In step 1 of the sequence, changed "Set the mode register current descriptor start mode bit, MRn[CDSM_SWSM], and the extended features enable bit MRn[XFE]." to "Set the mode register current descriptor start mode bit, MRn[CDSM_SWSM], and clear the extended features enable bit MRn[XFE]." |
| DMA source attributes register (DMA_SATRn)                 | For bit DMA_SATRn[SREADTTYPE], added setting "0111 Read, unlock L2 cache line".                                                                                                                                                                                                                 |

## **C.10 PCI Express Interface Controller Revision History**

| Reference                                                                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error capture registers (inbound error) Error capture registers (outbound error) PCI Express error capture register n | Removed the description of PEX_ERR_CAP_Rn from register section and added it to functional description (new sections error_capture_registers_inbound and error_capture_registers_outbound).                                                                                                                                                                                                                                           |
| (PEX_PEX_ERR_CAP_Rn)                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Initial credit advertisement                                                                                          | In Table 14-281, changed values from: PH=4, PD=(256/16)x4=64, NPH = 4 to: PH=6, PD=(256/16)x6=96, NPH = 8                                                                                                                                                                                                                                                                                                                             |
| PCI Express Advanced Error Capabilities and Control Register                                                          | Updated the reset value from '0x0000_0000' to '0x0000_00B0'.                                                                                                                                                                                                                                                                                                                                                                          |
| (Advanced_Error_Capabilities_and_Control_R egister)                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Memory map/register overview                                                                                          | Revised the addresses for registers in the PCI Express configuration space (all non-memory-mapped registers). These registers had incorrectly specified addresses. The offsets (the last three hexadecimal digits) were correct, but the registers were shown as if they had local memory map addresses instead of PCI Express configuration space addresses.                                                                         |
| PCI Express Controller Core Clock Ratio Register (Controller_Core_Clock_Ratio_Register)                               | Updated the first sentence in the second paragraph by specifying the PCI Express controller clock frequency as "200 MHz". The updated sentence reads as follows:                                                                                                                                                                                                                                                                      |
|                                                                                                                       | As an example of programming PEX_GCLK_RATIO, consider the case where the actual PCI Express controller clock is 200 MHz, the ratio of the actual clock to the default clock ( 267 MHz) is 3:4; that is, the default core clock has to be multiplied by the ratio (3/4, which is equivalent to 12/16).                                                                                                                                 |
| EP Boot mode and inbound configuration transactions                                                                   | Added the following text after the third paragraph: "If boot hold-off mode is desired in EP mode implementation, I2C boot sequencer must be used to pre-configure the respective EICn bit field of the SRDSCR3 and/or SRDSCR4 registers depending on the SerDes lane used for the PCI Express controller to ensure a successful link training. Refer to the notes described in SRDSCR3 and SRDSCR4 for further detailed information." |
| Type 0 configuration header registers and Type 1 configuration header registers                                       | In the Type 0 header figure, moved the Expansion ROM Base Address to 30h.                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                       | In the Type 1 header figure, added Expansion ROM Base Address at 38h.                                                                                                                                                                                                                                                                                                                                                                 |
| PCI Express Command Register (Command_Register)                                                                       | Revised notes for RC mode in Bus_master and Memory_space bit fields to describe unique treatment of transactions targeting PEXCSRBAR space.                                                                                                                                                                                                                                                                                           |
| PCI Express I/O Limit Upper 16 Bits Register                                                                          | Added the following note to access:                                                                                                                                                                                                                                                                                                                                                                                                   |
| (IO_Limit_Upper_16_Bits_Register)                                                                                     | Access is read/write in root complex and read only in endpoint.                                                                                                                                                                                                                                                                                                                                                                       |
| PCI Express Link Capabilities Register                                                                                | For bit 9-4, description is updated as:                                                                                                                                                                                                                                                                                                                                                                                               |
| (Link_Capabilities_Register)                                                                                          | Reset value depends upon the maximum link width of the PCI Express controller is capable of supporting.                                                                                                                                                                                                                                                                                                                               |
| PCI Express configuration address register (PEX_PEX_CONFIG_ADDR)                                                      | Revised the last sentence of register description to state, "the register address is: Extended register number II Register number II 00b."                                                                                                                                                                                                                                                                                            |
| PCI Express Interrupt Pin Register (Interrupt_Pin_Register)                                                           | Added a statement to register description that the register only applies to EP mode. Added footnote to register reset valuedistinguishing RC mode and EP mode reset values.                                                                                                                                                                                                                                                           |
| PCI Express Interrupt Pin Register (Interrupt_Pin_Register)                                                           | Added a statement to register description that the register only applies to EP mode.                                                                                                                                                                                                                                                                                                                                                  |

| Reference                                                           | Description                                                                                                |
|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| PCI Express Link Capabilities Register (Link_Capabilities_Register) | Updated the description of the following bits: Port Number, L1_EX_LAT, L0s_EX_LAT and ASPM.                |
| Outbound ATMU message generation and Inbound messages               | Moved discussion of Outbound ATMU messages and Inbound messages into the chapter's functional description. |
| PCI Express Device ID Register (Device_ID_Register)                 | For the Device_ID register, added the single core personalities.                                           |

# C.11 Enhanced Three-Speed Ethernet Controllers Revision History

| Reference                                                  | Description                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interpacket/interframe gap register (eTSEC_IPGIFG)         | Updated figure and table for the default value of Non-back-to-back Interpacket-Gap.                                                                                                                                                                                                                                                                       |
| Timer soft reset and reconfiguring procedure               | Updated first three steps as follows: Software must do the following before asserting TMR_CTRL[TMSR]:                                                                                                                                                                                                                                                     |
|                                                            | Place the controller in graceful transmit stop (DMACTL[GTS]=1, wait for IEVENTGn[GTSC]=1)                                                                                                                                                                                                                                                                 |
|                                                            | 2) Disable receive (MACCFG1[RX_EN]=0) - After setting timer soft reset (TMR_CTRL[TMSR]), software must leave the bit high for at least three 1588 reference clocks or tx_clk cycles, whichever is slower, before clearing the bit.                                                                                                                        |
| MII management configuration register (eTSEC_MDIO_MIIMCFG) | Added the following note: Note: when an eTSEC is configured to use TBI/RTBI, configuration of the TBI/RTBI (described in Section, "Ten-Bit Interface (TBI)") is done through the MIIM registers for that eTSEC. For example, if a TBI/RTBI interface is required on eTSEC2, then the MIIM registers starting at offset 0x2_5520 are used to configure it. |
| Serial gigabit media-independent interface                 | Updated the last sentence of the first paragraph from:                                                                                                                                                                                                                                                                                                    |
| (SGMII)                                                    | "Note that in SGMII, the eTSEC utilizes the on-board TBI PHY in addition to the SerDes interface."                                                                                                                                                                                                                                                        |
|                                                            | to:                                                                                                                                                                                                                                                                                                                                                       |
|                                                            | "Note that in SGMII, the eTSEC utilizes the on-Chip TBI PHY in addition to the SerDes interface."                                                                                                                                                                                                                                                         |
| eTSEC IEEE 1588 PTP memory map/<br>register definition     | In memory map table removed row for offset '0x0E88'; and register 'Timer fixed period interval n * (eTSEC1_1588_TMR_FIPER3)'. In register "Time stamp event register * (eTSEC1x_TMR_TEVENT)"; removed marked bit 26 as Reserved from PP3.                                                                                                                 |
| Figure 15-1068                                             | Removed third block for TMR_FIPER3 (1588_PULSE_OUT3) from figure "1588 Current Time Control".                                                                                                                                                                                                                                                             |
| Table 15-1074                                              | Removed row for "TMR_FIPER3" from table "Timer Clock Domain Timer Register List"                                                                                                                                                                                                                                                                          |
| Ethernet control register (eTSEC_ECNTRL)                   | GMIIM is set to 1 for RGMII 1Gbps, RGMII 100 Mbps, and RGMII 10 Mbps in eTSEC Interface Configurations table.                                                                                                                                                                                                                                             |

#### **Enhanced Three-Speed Ethernet Controllers Revision History**

| Reference                                                                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 15-1                                                                                                                                      | In eTSECn Network Interface Signal Properties table updated the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                 | Updated "_GTX_CLK125" to "EC _GTX_CLK125" and added the following: RGMII-Oscillator source for transmit clock; This clock can be configured to feed eTSEC3 only or feed eTSEC1 and eTSEC3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                 | Updated "1588_ ALARM_OUT2" to "TSEC_1588_ALARM_OUT2"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                 | Updated "1588_ PULSE_OUT2" to "TSEC_1588_PULSE_OUT2"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                 | Updated "1588_ ALARM_OUT2" to "TSEC_1588_ALARM_OUT2"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Reduced gigabit media-independent interface (RGMII)                                                                                             | Removed the duplicate figure "eTSEC-RGMII Connection".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Receive control register (eTSEC_RCTRL)                                                                                                          | Exposed L2OFF bit for RCTRL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Time stamp of general purpose external trigger * (eTSEC1_TMR_ETTSn_H) and Time stamp of general purpose external trigger * (eTSEC1_TMR_ETTSn_L) | Added "For time-stamping of back-2-back trigger events, the trigger edges can be no closer than 5 timer clocks apart." in the description of eTSEC1_TMR_ETTSn_H[ETTS_H] and eTSEC1_TMR_ETTSn_L[ETTS_L].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| TBI memory map/register definition                                                                                                              | Added two new registers: ANA_SGMII and ANLPBPA_SGMII.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| MII management address register (eTSEC_MDIO_MIIMADD)                                                                                            | Updated MIIMADD[PHY_Address] description from "This field represents the 5-bit PHY address field of Mgmt cycles . Up to 31 PHYs can be addressed (0 is reserved) . Its default value is 0x00." to "This field represents the 5-bit PHY address field used for mgmt cycles. At most, 31 external PHYs can be addressed, because one of the 32 possible addresses this field can hold is reserved for the TBI (internal PHY). At reset, the TBI PHY address is 0. However, PHY Address also defaults to 0; thus, by default, mgmt cycles go to the TBI. The MII PHY can use address 0 if the TBI PHY address is set to a non-zero value. The TBI PHY address is set in the TBIPA register. Note that writing a non-zero value to TBIPA makes that value reserved in the MII interface. " |
| Rx timer time stamp register high * (eTSEC_TMR_RXTS_H) and Rx timer time stamp register low * (eTSEC_TMR_RXTS_L)                                | Updated TMR_RXTS access from RW to RO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| User initialization                                                                                                                             | Updated the second and third bullet in the list that shows the order to bring the eTSEC into a functional state (out of reset).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Half-duplex control (eTSEC_HAFDUP)                                                                                                              | Updated the bit range of HAFDUP[Collision_Window] from 22:31 to 26:31.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Group Interrupt event register (eTSEC_IEVENTGn)                                                                                                 | In IEVENTG register description, added "MSRO" in the sentence "FIQ, DPE, PERR, EBERR, XFUN, TWK"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Table 15-1073                                                                                                                                   | Added entry for TWK in the table.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Transmit control register (eTSEC_TCTRL)                                                                                                         | Added note: Except for TFC_PAUSE and THDF, which may be updated on-the-fly, no TCTRL field values should be upated without a GTSC (graceful transmit stop complete).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| eTSEC external signals description                                                                                                              | <ol> <li>In the second paragraph, updated TxD[7:0] to TxD[3:0].</li> <li>Removed references to TSECn_TXD[7:4] and TSECn_RXD[7:4] from the eTSECn network interface signal properties table.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Detailed signal descriptions                                                                                                                    | Removed references to TSECn_TXD[7:4] and TSECn_RXD[7:4] from the eTSEC signals-detailed signal descriptions table.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Connecting to physical interfaces on<br>Ethernet                                                                                                | In the second paragraph, updated TSECn_TXD[7:0] to TSECn_TXD[3:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Table 15-1109                                                                                                                                   | Removed references to TxD[4:7] and RxD[4:7].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Table 15-1112                                                                                                                                   | Removed references to TxD[4:7] and RxD[4:7].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Reference     | Description                                  |
|---------------|----------------------------------------------|
| Table 15-1115 | Removed references to TxD[4:7] and RxD[4:7]. |

## C.12 Enhanced Secure Digital Host Controller Revision History

| Reference                                                  | Description                                                                                                                                                                |
|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Commands for MMC/SD                                        | In the Commands for MMC/SD/SDIO/CE-ATA table, added CMD8 row for SD Cards.                                                                                                 |
|                                                            | Also, added the following note: "CMD8 differs for MMC and SD cards. For SD cards, CMD8 is referred to as SEND_IF_COND. For MMC cards, CMD8 is referred to as SEND_EXT_CSD" |
| Reset                                                      | Removed reference to SDIO in the figure, figure caption and the pseudocode                                                                                                 |
| Enhanced Secure Digital Host Controller (eSDHC) Memory Map | Reinstated the note regarding register access restriction prior to the memory map table.                                                                                   |
| Interrupt status (eSDHC_IRQSTAT)                           | Added a note to IRQSTAT[CCE] and IRQSTAT[CIE]                                                                                                                              |
| Host controller version (eSDHC_HOSTVER)                    | For HOSTVER(VVN), added bit value definition for 01.                                                                                                                       |
| System control (eSDHC_SYSCTL)                              | Changed the maximum SD clock frequency to 52 MHz for SYSCTL(16-23).                                                                                                        |
|                                                            | Also, updated the second example given to yield a clock value of400 kHz.                                                                                                   |

## C.13 Universal Serial Bus Interface Revision History

| Reference                                                                                                                               | Description                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ping control                                                                                                                            | Added following: Note: For high-speed bulk and control                                                                                                                                                                                                                                                                              |
| Control (USB_CONTROL)                                                                                                                   | Changed USB_CONTROL[29] bit name to USB_EN                                                                                                                                                                                                                                                                                          |
| Port status/control (USB_PORTSC)                                                                                                        | For PIC[15–14], added a note saying "The PORTSC[14] is mapped to PCTL0 and PORTSC[15] is mapped to PCTL1."                                                                                                                                                                                                                          |
| Host controller structural parameters (USB_HCSPARAMS)                                                                                   | Updated the HCSPARAMS register reset value to read as 0x1101_0000                                                                                                                                                                                                                                                                   |
| USB command (USB_USBCMD)                                                                                                                | Updated USBCMD[ITC] bit from "Read-only" to "Read/Write"                                                                                                                                                                                                                                                                            |
| Master interface data burst size (USB_BURSTSIZE), Transmit FIFO tuning controls (USB_TXFILLTUNING), and Endpoint flush (USB_ENDPTFLUSH) | Updated the following register names:              Name of BURSTSIZE from Programmable burst size to Master interface data burst size             Name of TXFILLTUNING from Host TT transmit pre-buffer packet tuning to Transmit FIFO tuning controls             Name of ENDPTFLUSH from Endpoint de-initialize to Endpoint flush |
| Capability register length (USB_CAPLENGTH)                                                                                              | Updated the description of CAPLENGTH bit.                                                                                                                                                                                                                                                                                           |

#### **Enhanced Serial Peripheral Interface Revision History**

| Reference                                        | Description                                                                                                                                                                                                  |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master interface data burst size (USB_BURSTSIZE) | Added the following text after first paragraph:                                                                                                                                                              |
|                                                  | Note that BURSTSIZE[TXPBURST] and BURSTSIZE[RXPBURST] are effectively write-only fields . The actual value written in the register is used correctly for the burst length, but the fields always return 10h. |
| Port status/control (USB_PORTSC)                 | Added the following sentence in the PTC bit description.                                                                                                                                                     |
| ULPI register access                             | Added the following note before the register figure:                                                                                                                                                         |
| (USB_ULPI_VIEWPORT)                              | "Read or write to the ULPI PHY extended register set (address > 3Fh) is not supported."                                                                                                                      |
| Host controller structural parameters            | Added following in description of USB_HCSPARAMS[PPC]:                                                                                                                                                        |
| (USB_HCSPARAMS)                                  | ULPI Mode:                                                                                                                                                                                                   |
|                                                  | 0 – USBDR will write 0 for DrvVbus bit of OTGControl register in PHY.                                                                                                                                        |
|                                                  | 1 – USBDR will write 1 for DrvVbus bit of OTGControl register in PHY.                                                                                                                                        |
|                                                  | The OTGControl register is defined in ULPI specification.                                                                                                                                                    |
| Identification register (USB_ID)                 | Updated bit fields for ID register.                                                                                                                                                                          |
| USB memory map/register definition               | Updated descriptions for USBSTS[PCI], PORTSC[CCS], PORTSC[PP], PORTSC[PIC], and USBCMD[RST] bit fields.                                                                                                      |
| Table 17-66                                      | Updated the Queue Head Layout table.                                                                                                                                                                         |
| Device controller initialization                 | Added paragraph starting with "To configure the external ULPI PHY" below the second paragraph.                                                                                                               |
| Host controller initialization                   | Added paragraph starting with "To configure the external ULPI PHY" below the first paragraph.                                                                                                                |

## **C.14 Enhanced Serial Peripheral Interface Revision History**

| Reference                                      | Description                                                                                           |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| ESPI detailed signal descriptions              | Changed MOSI to I/O (was just O) because it can serve as a second input for Winbond dual output read. |
| 16-bit address example, 24-bit address example | Swapped the 5th and 6th espi intialisation sequence.                                                  |

## **C.15** Device Performance Monitor Revision History

| Reference                  | Description                                                                   |
|----------------------------|-------------------------------------------------------------------------------|
| Performance monitor events | In Table 19-44, updated:                                                      |
|                            | - Count is changed from C8:81 to C7:78 for the event "ECM dispatch from PEX1" |
|                            | - Count is changed from C2:84 to C2:85 for the event "ECM dispatch to PEX1"   |

### **C.16 Global Utilities Revision History**

| Reference                                                                               | Description                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alternate function signal multiplex control (GUTS_PMUXCR)                               | Updated the third paragraph to read as follows: "CE_PA[31], CE_PB[0:7], CE_PB[11], CE_PB[29:31], and CE_PC[0] always functions as QE pins irrespective of the status of PMUXCR bits" |
|                                                                                         | Updated the PMUXCR[QE0] bit description.                                                                                                                                             |
| Device disable register (GUTS_DEVDISR)                                                  | In the third paragraph of register description, added "Note that timer block (bit [TB0, TB1]) can be enabled or disabled without hard reset."                                        |
| POR PLL ratio status register (GUTS_PORPLLSR)                                           | Updated reset value of bit 25 to n.                                                                                                                                                  |
| POR device status register 2 (GUTS_PORDEVSR2)                                           | Updated reset value of bit 6 to n.                                                                                                                                                   |
| SRDS Control Register 2 (GUTS_SRDSCR2)                                                  | Updated reset value to 0x0000_0040.                                                                                                                                                  |
| SRDS Control Register 3<br>(GUTS_SRDSCR3) and SRDS Control<br>Register 4 (GUTS_SRDSCR4) | Updated bit 4 and 5 as reserved from HSEN0 and HSEN1 in SRDSCR3 and HSEN2 and HSEN3 in SRDSCR4 registers.                                                                            |

# C.17 Debug Features and Watchpoint Facility Revision History

| Reference                        | Description                                                                                                                                                 |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Debug information on debug pins  | Updated the first sentence to read as follows:                                                                                                              |
|                                  | If cfg_mem_debug is high when sampled during POR, the debug information from the DDR SDRAM controller is driven on MSRCID[0:4] and MDVAL.                   |
| Debug information on ECC pins    | Updated the first sentence to read as follows:                                                                                                              |
|                                  | If cfg_ddr_debug is low when sampled during POR, debug information from the DDR SDRAM interface is selected to appear on MECC[0:5] as shown in Figure 21-1. |
| Local bus interface debug        | Updated the first sentence to read as follows:                                                                                                              |
|                                  | If cfg_mem_debug is low when sampled during POR, the eLBC is selected as the source for the debug information appearing on MSRCID[0:4] and MDVAL.           |
| Table 21-1                       | Corrected the CFG_MEM_DEBUG and CFG_DDR_DEBUG signals to active high.                                                                                       |
| Memory debug mode (eLBC and DDR) | Corrected the CFG_MEM_DEBUG signal to active high.                                                                                                          |
| DDR SDRAM interface debug mode   | Corrected the CFG_DDR_DEBUG signal to active high.                                                                                                          |
| Table 21-4                       | Updated the reset value of MDVAL from '1' to '0'.                                                                                                           |

## C.18 P1021 QUICC Engine Overview Revision History

| Reference          | Description                                                                                                                     |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| HDLC controller    | Updated the ratio between the HDLC interface serial clock frequency and the QUICC Engine clock frequency to read as 1:3.        |
| HDLC controller    | Added a note to state that HDLC serial clock must not exceed the maximal frequency as specified in the Hardware specifications. |
| QUICC engine block | Updated the HDLC clock frequency from 70 Mbps to 50 Mbps.                                                                       |

#### How to Reach Us:

#### **Home Page:**

www.freescale.com

#### Web Support:

http://www.freescale.com/support

#### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor
Technical Information Center, EL516
2100 East Elliot Road
Tempe, Arizona 85284
+1-800-521-6274 or +1-480-768-2130
www.freescale.com/support

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor China Ltd.
Exchange Building 23F
No. 118 Jianguo Road
Chaoyang District
Beijing 100022
China
+86 10 5879 8000
support.asia@freescale.com

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductors products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claims alleges that Freescale Semiconductor was negligent regarding the design or manufacture of

RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics as their non-RoHS-complaint and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative.

For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp.

Freescale<sup>TM</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners.

© 2010-2013 Freescale Semiconductor, Inc.



Document Number: P1021RM

Rev. 6, 01/2013

